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Соругідііі: ( с ) 1994 Техническим Комитетом ХЗЛ4. Все права зарезервированы. 

Это - рабочий документ Технического Комитета (ТК) ХЗЛ4, который представляет 
последний проект А№ РогіІі представленный в А№1 для публикации. Настоящим 
предоставляются права копировать этот документ при условии, что он скопирован 
полностью без изменений или изменен посредством: 

(1) добавления текста, который ясно отмечен как вставка; 

(2) затенения или выделения существующего текста; и/или 

(3) удаления примеров. 

В частности, предоставляются права использовать этот рабочий документ как 
основу для учебников, системных руководств, и диалоговой документации, если 
выполнены требования предыдущего параграфа, и результирующий продукт отвечает 
техническим потребностям, не удовлетворенным официальным А№. 

ПРИМЕЧАНИЕ: Этот файл предоставлен как рабочий документ ТК для общественного 
обсуждения и комментирования а также для использования в документации, 
описанной выше. Он не предназначен как замена Официального А№ РогіІі документа, 
опубликованного А№1. В случае конфликта, только напечатанный документ Х3.215- 
1994 представляет официальный А№ Рогііі. 

Для получения официального стандарта, пожалуйста, свяжитесь с Атегісап Маііопаі 
Зіапсіагсіз Іпзіііиіе Заіез Оерагітепі, в (212) 642-4900 или ФАКС (212) 302-1286, 
или ОІоЬаІ Епдіпеегіпд Ооситепіз, в (800) 854-7179 или ФАКС (303) 843-9880, и 
запросите Документ ХЗ.215-1994. 

Большое спасибо за ваш интерес. 
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Предисловие 

( Это предисловие - не часть Американского Национального Стандарта ХЗ.215-1994) 
РогІИ - язык для непосредственной связи между людьми и машинами. Используя 
стиль естественного языка и машинно-ориентированный синтаксис, РогІН 
обеспечивает экономичную, производительную среду для интерактивной трансляции и 
выполнения программ. РогІН также обеспечивает низкоуровневый доступ к 
управляемым компьютером аппаратным средствам, и возможность расширять язык 
непосредственно. Эта расширяемость позволяет быстро расширять язык и 
приспосабливать его к специфичным потребностям и различным аппаратным системам. 

РогИп был изобретен г. Чарльзом Муром, чтобы увеличить производительность 
программиста без принесения в жертву машинной эффективности. Рогіііі - 
многоуровневая среда, содержащая элементы машинного языка, а также операционную 
систему и машинный монитор. Эта расширяемая, многоуровневая среда предусмотрена 
для высоко интерактивной разработки и отладки программ. 

В интересах переносимости прикладного программного обеспечения, написанного в 
РогІИ, работы по стандартизации начались в середине 197Ѳ-ых международной 
группой пользователей и разработчиков, принявших название "РогІП Зіапсіагсіз 
Теат". Эти работы завершились стандартом РогІИ-77. Поскольку язык продолжил 
развиваться, "РогІИ Зіапсіагсіз Теат" был издан промежуточный стандарт РогІИ-78. 
Следующая встреча "РогІИ Зіапсіагсіз Теат" была в 1979, а РогІИ-79 стандарт был 
издан в 1980. Главные изменения были сделаны "РогИп Зіапсіагсіз Теат" в РогІІі-83 
стандарте, который был издан в 1983. 

Первая встреча Тесііпісаі Соттііііее по системам программирования на РогІИ была 
созвана Оргкомитетом ХЗЛ4 РогІП Тесбпісаі Соттіііее 3 августа 1987, с 
последующими встречами 11-12 ноября 1987, 10-12 февраля 1988, 25-28 мая 1988, 
10-13 августа 1988, 26-29 октября 1988, 25-28 января 1989, 3-6 мая, 1989, 26- 
29 июля 1989, 25-28 октября 1989, 24-27 января 1990, 22-26 мая 1990, 21-25 
августа 1990, 6-10 ноября 1990, с 29 января по 2 февраля 1991, 3-4 мая 1991, 
16-19 июня 1991, с 30 июля по 3 августа 1991, 17-21 марта 1992, 13-17 октября 
1992, 26-30 января 1993, 28-30 июня 1993, и 21 июня 1994. 

Запросы об интерпретации, предложения по исправлениям и дополнениям, или отчеты 
об ошибках принимаются. Они должны быть посланы в ХЗ Секретариат, Сотриіег апсі 
Визіпезз Ециіртепі; МапиТасІигегз Аззосіаііоп, 1250 Еуе Зігееіі, МИ, Зиііе 200, 
Мазіііпдііоп, ЭС 20005. 
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ХЗ Состав 

Этот стандарт был разработан и одобрен для представления в АМЗІ при 
Ассгесііііесі Зіапсіагсіз Соттіііее оп Іп'РогтаІіоп Ргосеззіпд Зуз1;ет5,ХЗ. Одобрение 
комитетом этого стандарта не подразумевает обязательно, что все члены комитета 
голосовали за его одобрение. Во время одобрения этого стандарта, ХЗ Комитет 
имел следующий состав: 

Эатез О. Сопѵегзе, СПаіг 
Оопаісі С. ЦоидПгу, Ѵісе-СПаіг 
Эоаппе Ріападап, Зесгеііагу 


Ргосіисег Сгоир 


Мате оі" Рергезепііаіііѵе 






АМР ІпсогрогаіесІ . 

АТ&Т/ІМСР Согрогаііоп . 

Арріе Сотриіег, Іпс . 

Сотрад Сотриіегз . 

Оідііаі Едиіртепі Согрогаіііоп . 

Нііасііі Атегіса І_ісІ . 

Неміеіі РаскагсІ . 

Виіі НМ Іпіогтаііоп Зузіетз Іпс 
ІВМ Согрогаіііоп . 

ІІпізуз Согрогаіііоп . 

Зопу Согрогаііоп оі Атегіса ... 
Зіогаде Тесііпоіоду Согрогаііоп 

Зип Місгозузіетз, Іпс . 

Хегох Согрогаііоп . 

ЗМ Сотрапу . 


ЕсІмагсІ Кеііу 
Сііагіез Вгііі (Аіі.) 
Тііотаз VI. Кегп 
Тііотаз Р. Ргозі (Аіі.) 
Кагеп НіддіпЬоііот 
Іатез Вагпез 
ОеІЬегі Зііоетакег 
Кеѵіп І_еіл/із 
Іоііп Меитапп 
Кеі Уатазііііа (Аіі.) 
Оопаісі С. І_оидіігу 
Мііііат Сеогде 
Іоеі ІІгтап 

Магу Аппе 1_ам1ег (Аіі.) 
Іоііп НІИ 

Зіерііеп Р. Окзаіа (Аіі.) 

Місііаеі Оеезе 

Іозеріі 5. гадасгкомзкі 

Затиеі 0. Сііеаіііат (Аіі.) 

Зсоіі Іатезоп 

Сагу 5. РоЬіпзоп (Аіі.) 

Омідііі МсВаіп 

Роу Ріегсе (Аіі.) 

Есііе Т. Могіока 
Раиі Р. Іаііпке (Аіі. 


Сопзитегз Сгоир 

Воеіпд Сотрапу . Саіііегіпе Номеііз 

Апсігеа Ѵапозсіоіі (Аіі.) 

Еазітап Косіак Сотрапу . Іатез Сопѵегзе 

Місііаеі Иіег (Аіі.) 

Сепегаі Зегѵісез Асітіпізігаііоп . Ооидіаз Агаі 

іаггу І_. Іаскзоп (Аіі.) 

Сиісіе Іпіегпаііопаі Іпс . Ргапк КігзііепЬаит 

Нагоісі Кипеке (Аіі.) 

Нидііез Аігсгаіі Сотрапу . Нагоісі 2еЬгаск 

Маііопаі Соттипісаііопз Зузіетз . Оеппіз Восізоп 


7 


Могіііегп Теіесот Іпс . Меі Іл/оіпзку 

ЗиЬііазіі Раіеі (Аіі.) 

Ресодпіііоп Тесіі ІІзегз Аззосіаііоп . НегЬегі Р. Зсііапіг 

6. Есііл/іп Наіе (Аіі.) 

Зііаге Іпс . Сагу Аіпзіл/огііі 

ОаѵісІ Тііеіл/із (Аіі.) 

II. 5. Оерагітепі оі Оеіепзе . Іліііііат Ріпеііиіз 

С. 1. Раздиагіеііо (Аіі.) 

II. 5. Оерагітепі оі Епегду . Аііоп Сох 

І_аѵ\/гепсе А. Іліаззоп (Аіі.) 

Ілііпіегдгееп Іпіогтаііоп Зегѵісез . Іоііп Іліііееіег 


Сепегаі Іпіегезі Сгоир 

Атегісап Мисіеаг Зосіеіу . Сегаісііпе С. Маіп 

Заііу Нагігеіі (Аіі.) 


Аззп. оі іііе Іпзіііиіе іог Сегіііісаііоп 

оі Сотриіег Ргоіеззіопаіз . Кеппеііі 2етгоіл/зкі 

Маі'І Іпзіііиіе оі Зіапсіагсіз апсі Тесііпоіоду .. РоЬегі Е. Роипігее 

Місііагі Нодап (Аіі.) 

Меѵіііе & Аззосіаіез . Сагііоп Меѵіііе 

































Воздержался 


* * 


Нет данных 
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ХЗЛ4 Состав 


Во время одобрения этого проекта предложенного Атегісап Маііопаі ЗіапсІагсІ, 
ТесЬпісаІ Соттіііее ХЗЛ4 по зыку программирования РогТЬ имел следующий состав: 


ЕІігаЬеТЬ Разбег, СЬаіг 

МіТсЬ ВгасІІеу, асТіпд Ѵісе-СЬаіг 

Роп СоІЬигп, ЗесгеТагу 

ІоЬп РіЬІе, Тесііпісаі ЕсІіТог 

Ееп 2еТТе1, ѴосаЬиІагу РергезепТаТіѵе 

Сгед Ваііеу, Тесііпісаі ЗиЬсоттіТТее СІіаіг 

Мате оТ РергезепТаТіѵе 
Сгед Ваііеу 

Номе Ропд (АН.) 

МіТсЬ ВгасІІеу 
Роп СоІЬигп 
ЬеопагсІ Р. 2еТТе1, 1г. 
ЕІігаЬеТЬ РаТЬег 
Реппіз РиТТег (АІТ.) 
Ьамгепсе Рогзіеу 
Ногасе Зіттопз (АІТ.) 
ІоЬп Науез 
Раѵе Наггаізоп 
Іатез РазЬ 
ІоЬп К. ЗТеѵепзоп 
Сагу ВеТТз 

ЗіерЬеп ЕдЬегі (АІТ.) 
Магііп Тгасу 
Іаск МоеЬг 

Іпсііѵісіиаі МетЬегз 
Ьогіпд Сгаутег 
ЛоЬп РіЬІе 
1. Е. (ІеТ) ТЬотаз 

ХЗ Ьіазопз 
Сіусіе Р. Сатр 
КаіЫееп МсМіІІап 


ВгасІІеу РогТЬмаге . 

Сгеаііѵе ЗоІиТіопз, Іпс . 

РогсІ Моіог Сотрапу . 

РОРТН, Іпс . 

ІпзТіТиТе Тог Аррііесі РогТЬ РезеагсЬ . 

ІоЬпз Норкіпз ІІпіѵегзіТу, Аррііесі РЬузісз І_аЬ. 

МерЬізіорЬеІез Зузіетз . 

ИАЗА/босІсІагсІ Зрасе РІідЬТ СепТег . 

ІМотасІіс ЗоТТмаге . 

ІІпізуп, Іпс . 

ІІр апсі Риппіпд . 

Ѵезіа ТесЬпоІоду . 


ОгдапігаТіоп РергезепТесІ 
АТНЕМА Ргодгаттіпд, Іпс 


Следующие организации и частные лица также участвовали в этом проекте как члены 
ТесЬпісаІ СоттіТТее, заместители, или наблюдатели. ТесЬпісаІ СоттіТТее ценит и 
уважает их вклад: 


ОгдапігаТіопз 

ВгііізЬ СоІитЬіа Іпзі. оТ ТесЬ. 
СотриТег СомЬоуз 
СотриТег Зсіепсез Согр. 

СотриТег Зігаіедіез, Іпс. 


Рідаіод Согр. 

ЕтЬесІсІесІ Зуз . Ргодгаттіпд Мад . 
РогТЬ ІпТегезТ Сгоир (РІ6) 


МСІ ТеІесоттипісаТіопз Согр. 
МісготоТіоп 

МісгоРгосеззог Епдіпеегіпд І_ТсІ. 
Маііопаі ІпзТіТиТе оТ ЗТапсІагсІз & 
ТесЬпоІоду 
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МСР Месіісаі Зузіетз Сгоир 
РегТогтапсе Раскадез, Іпс. 

Ригсіие ІІпіѵегзііу 
















Н.В. Разсаі & Со., Іпс. 


РоЬегІ: Вегкеу Зегѵісез 


Наггіз Зетісопсііісііог 
ІВМ Согрогаііоп 
ІЕЕЕ 

Кеііу Епіегргізез 
ЦаЬогаіогу Місгозузіетз, Іпс. 
Махіог Согр. 


ЗНам ЦаЬогаіогіез 

Зосіаі Зесигііу Асітіпізіігаіііоп 

Зобіиате Епдіпеегіпд 

Техаз Іпзігитепіз 

ТНе Оіскепз Сотрапу 


Іпсііѵісіиаіз 
ОаѵісІ 3 . Апдеі 
МП Васіеп 
РоЬегб Вегкеу 
Коп Вгаііііиаіііе 
Эаск Вгомп 
СНгіз СоІЬигп 
ТесІ Оіскепз 
ЭоНп ОогЬапсІ 


Кау Оипсап 
Ооидіаз РізИтап 
Тот НапсІ 
Сгедогу Ид 
СНагІез Кеапе 
Сиу М. Кеііу 
Апсігем КоЬгіаг 
Магііп Еазсеііез 


СНагІез Мооге 
Міке ІМетеіІі 
Наггу Разсаі 
ЗіерИеп Реіс 
Оеап Реггіпе 
ОаѵісІ С. Реііу 
ВІ11 Радзсіаіе 
Эатез Руіапсі 


Оеап Запсіегзоп 
Сеогде ЗНам 
Сегаісі ЗІііігіп 
РоЬегі Зтіііі 
Туіег Зреггу 
Тот 2іттег 
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АМЕРІСАИ І\ІАТІОІ\ІАІ_ 5ТАШАК0 
АІМ5І ХЗ. 215-1994 


Американский Национальный стандарт 

для Информационных Систем 

Языки Программирования — 


Рогііі 

Рогііі 

Рогііі 


1 . _ 

Введение 

1.1 _ 

Цель 

Цель этого Стандарта состоит в том, чтобы способствовать переносимости РогіН 
программ для использования на большом разнообразии вычислительных систем, чтобы 
облегчить обмен программами, методами программирования, и идеями среди 
программистов РогШ, и служить как основание будущего развития языка РогіИ. 

1.2 _ 

Назначение 

Этот Стандарт устанавливает интерфейс между РогіН системой и РогіН программой 
определением слов, предусмотренных Стандартной Системой. 

1 . 2.1 _ 

Включения 

Этот Стандарт определяет: 

- формы, которые может иметь программа, написанная на языке Рогііі; 

- правила для интерпретации смысла программы и ее данных. 

1 . 2.2 _ 

Исключения 


Этот Стандарт не определяет: 



- механизм, которым программы преобразованы для использования на вычислительных 
системах; 

- операции, требуемые для установки и контроля за выполнением программ на 
вычислительных системах; 

- метод переноса программ или их входных/выходных данных на носитель или из 
носителя данных; 

- поведение программы и РогІИ системы, в случаях не установленных правилами 
этого Стандарта; 

- размер или сложность программы и ее данных, которые способны превысить 
вместимость какой либо вычислительной системы или возможности конкретной 
РогІП системы; 


11 


- физические свойства записей ввода/вывода, файлов, и модулей; 

- физические свойства и реализация памяти. 

1.3 _ 

Организация документа 

1.3.1 _ 

Наборы слов 

Этот Стандарт группирует РогІН слова и свойства в наборы слов под именами 
указывающими на некоторые общие свойства, типично их общая область 
функционирования. Каждый набор слов может иметь расширение, содержащее слова, 
которые предлагают дополнительные функциональные возможности. Эти слова - не 
требуются в реализации набора слов. 

"Основной" набор слов, определенный в разделах с 1 по 6, содержит требуемые 
слова и свойства стандартной Системы. Другие наборы слов, определенные в 
разделах с 7 по 17, являются дополнительными, делая возможным расширение 
стандартной Системы дополнительными уровнями функциональности. 

1.3.1.1 _ 

Текстовые разделы 

В пределах каждого набора слов, раздел 1 содержит вводный и объяснительный 
материал, а раздел 2 представляет термины и нотацию, используемые в Стандарте. 
Нет никаких требований в этих разделах. 

Разделы 3 и 4 содержат требования использования и документации, соответственно, 
для стандартных Систем и программ, в то время как раздел 5 определяет их 
наименование. 

1.3.1.2 _ 

Разделы словаря 

Раздел 6 каждого набора слов определяет требуемое поведение определений в 
наборе слов и наборе слов расширений. 

1.3.2 _ 

Дополнения 

Дополнения не содержат никакого требуемого материала. 

Приложение А предоставляет некоторые разъяснения вслед за решениями комитета в 
создании этого Стандарта, а также примеры реализации. Та же самая нумерация 
раздела, что и в теле Стандарта, облегчает связь каждого раздела требований с 
его разделом объяснений. 


Приложение В - короткая библиография РогІИ. 



Приложение С предоставляет введение в Рогій. 

Приложение Р обсуждает совместимость А№ Рогбб с более ранними РогбИ, 
подчеркивая различия с Рогбб 83. 

Приложение Е представляет некоторые методы для создания переносимых программ в 
А№ Рог ІИ. 
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Приложение Р включает слова из всех наборов слов в одном списке, и служит как 
индекс А№ Рогбб слов. 

1.4 _ 

Будущие направления 

1.4.1 _ 

Новая технология 

Этот Стандарт принимает некоторые слова и практики, которые все более и более 
находятся в общей практике. Также были приняты новые слова для облегчения 
создания переносимых программ. 

1.4.2 _ 

Устаревшие функции 

Этот Стандарт принимает некоторые слова и практики, которые делают некоторых 
ранее используемые слова устаревшими. Хотя они сохранены здесь из-за их 
широкого распространения, их использование в новых реализациях или новых 
программах не рекомендуется, потому что они могут быть изъяты из будущих 
редакций Стандарта. 

Этот Стандарт определяет следующие слова как устаревшие: 

6.2.0060 #ТІВ 15.6.2.1580 РОРСЕТ 6.2.2240 ЭРАМ 

6.2.0970 СОІМѴЕРТ 6.2.2040 фІІЕПѴ 6.2.2290 ТІВ 

6.2.1390 ЕХРЕСТ 
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2 . _ 

Термины, нотация, и ссылки 

Фраза "Смотри:" используется в этом Стандарте для направления читателя к другим 
разделам Стандарта, которые имеют прямое отношение к текущему разделу. 

В этом Стандарте, "следует" устанавливает требование к системе или программе; 
наоборот, "не следует" является запрещением; "не требуется" означает "не 
требуется для"; "желательно" описывает рекомендации Стандарта; и "возможно", в 
зависимости от контекста, означает "разрешено" или "может случаться". 

Повсюду в Стандарте, шрифты используются следующим способом: 

- этот пропорциональный ЗегіТ шрифт используется для текста, с курсивом, 
используется для символов и первого появления новых терминов; 

- полужирный пропорциональный запз-зегіТ шрифт используется для заголовков; 

- полужирный ЗегіТ шрифт фиксированной ширины используется для текста языка- 
РогТб. 

2.1 _ 

Определения терминов 


Термины, определенные в этом разделе используются вообще повсюду в этом 



Стандарте. Дополнительные термины специфичные для определенных наборов слов, 
определены в этих наборах слов. Другие термины, определенные при их первом 
появлении, обозначены курсивом. Термины, не определенные в этом Стандарте, 
рассматриваются согласно Словарю для Информационных Систем, А№1 ХЗ.172-1990. 

адресуемый элемент: В зависимости от контекста: 

1) элементы, на которые разделено адресное пространство Рогбй с целью 
размещения объектов данных типа символов и переменных; 

2) физические запоминающие элементы памяти, соответствующие этим элементам; 

3) содержание такого запоминающего элемента памяти; 

4) или элементы, в которых непосредственно указана длина области памяти. 

выровненный адрес: Адрес местоположения в памяти, к которому можно обращаться 
как к символу, ячейке, паре ячеек, или целым числам две-ячейки. 

неопределенная ситуация: Обстоятельство, для которого этот Стандарт не 
предписывает определенного поведения для Рогбй систем и программ. 

Неопределенные ситуации включают такие вещи как отсутствие необходимого 
разделителя во время синтаксического анализа, попытку доступа к несуществующему 
файлу, или попытку использования несуществующего слова. 

Неопределенная ситуация также существует, когда Стандартное слово получает 
значения, которые являются неподходящими или выходящими из диапазона. 

ячейка: Первичный элемент информации в архитектуре Рогбй системы. 

пара ячеек: Две ячейки, которые рассматриваются как один элемент. 

символ: В зависимости от контекста: 

1) элемент памяти, способный хранить символ; или 

2) элемент набора символов. 
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символьно-выровненный адрес: Адрес местоположения в памяти, к которому можно 
обратиться как к символу. 

символьная строка: Область данных, которая связана с непрерывной 
последовательностью символьно-выровненных адресов. Символьные строки обычно 
содержат текст. Если иначе не обозначено, термин "строка" обозначает 
"символьную строку". 

область кода: Логическая область словаря, в котором реализована семантика 
слова. 

компилировать: Преобразовать исходный текст в определения словаря. 

семантика компиляции: Поведение Рогбй определения, когда его имя встречает 
текстовый интерпретатор в состоянии компиляции. 

строка со счетчиком: Структура данных, состоящая из одного символа, 
содержащего длину следующей за ним нулевой или более непрерывной 
последовательности символьных данных. Обычно, строки со счетчиком содержат 
текст. 

кросс компилятор: Система, которая компилирует программу для последующего 
выполнения в среде, которая возможно, будет физически и логически отличной от 
среды компилирования. В кросс компиляторе, термин "йозб" применяется к среде 
компиляции, а термин "Іагдеі;" применяется к среде времени-выполнения. 

текущее определение: Определение, чья компиляция была начата, но еще не 
закончена. 



поле данных: Область данных связанная со словом, определенным через, СРЕАТЕ. 

область данных: Логическая область словаря, к которой можно обращаться. 

указатель области данных: Адрес местоположения следующей доступной области 
данных, то есть, значение, возвращенное НЕКЕ. 

стек данных: Стек, который можно использовать для передачи параметров между 
определениями. Когда не возможна путаница, стек данных упомянут как "стек". 

В отличие от стека возвратов. 

тип данных: Идентификатор для набора значений, который может иметь объект 
данных. 

определяющее слово: РогІИ слово, которое создает новое определение при 
выполнении. 

определение: РогИп выполняемая процедура, откомпилированная в словарь. 

словарь: Расширяемая структура, которая содержит определения и связанные 

области данных. 

отобразить: Послать один или более символов на устройство вывода пользователя. 

зависимости от окружения: Неявные программные предположения об опциях 
реализации Рог 1;И системы или используемого оборудования. Например, программы, 
которые принимают размер ячейки больший, чем 16 бит, считаются зависимыми от 
окружения. 

семантика выполнения: Поведение РогИп определения, когда оно выполняется. 
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маркер выполнения: Значение, которое идентифицирует семантику выполнения 
определения. 

искать: Просмотреть словарь для имени определения, соответствующего данной 

строке. 

слово немедленного исполнения: РогИп слово, чья семантика компиляции должна 
выполнить его семантику выполнения. 

определяемое реализацией: Обозначает системное поведение или особенности, 
которые должны быть обеспечены и документированы системой, но которые более 
детально не определены этим Стандартом. 

зависящее от реализации: Обозначает системное поведение или особенности, 
которые должны быть обеспечены системой, но которые более детально не 
определены этим Стандартом. 

входной буфер: Область памяти, содержащей последовательность символов из 
входного источника, которая настоящее время доступна для программы. 

входной источник: Устройство, файл, блок, или другой источник, который 
поставляет символы для пополнения входного буфера. 

спецификация входного источника: Набор информации, описывающей подробное 
состояние входного источника, входного буфера, и области анализа. Этой 
информации достаточно, для корректного сохранения и восстановления для 
обеспечения операций вложенного синтаксического анализа в том же или другом 
входном источнике. 


семантика интерпретации: Поведение РогІП определения, когда его имя встречает 



текстовый интерпретатор в состоянии интерпретации. 


событие клавиатуры: Значение, полученное системой, обозначающее 
пользовательское действие на пользовательском входном устройстве. Термин 
"клавиатура" в этом документе не исключает другие типы пользовательских входных 
устройств. 

строка: Последовательность символов, с последующим фактическим или 

подразумеваемым признаком конца строки. 

область имен: Логическая область словаря, в которой сохранены имена 
определений. 

число: В этом Стандарте, "число" используемое без других оговорок, означает 
"целое число". Аналогично "двойное число" означает "целое число две-ячейки". 

анализ: Выбрать и исключить символьную строку из области анализа, используя 

заданный набор символов разделителей, называемых разделителями. 

область анализа: Часть входного буфера, которая еще не анализировалась, и 
таким образом доступна системе для последующей обработки текстовым 
интерпретатором или другими операциями синтаксического анализа. 

вывод отображаемого числа: Формат числового вывода, в который преобразовано 
число, используя РогСй слова, который напоминает символическое "изображение" 
желаемого вывода. 

программа: Законченная спецификация выполнения, для выполнения определенной 
функции (прикладной задачи) выраженная в форме исходного текста Рогій. 
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принять: Получить символы из пользовательского входного устройства. 

стек возвратов: Стек, который можно использовать для вложенного выполнения 
программ, выполнения сіо-іоор, временной памяти, и других целей. 

стандартное слово: Именованная РогСй процедура, формально определенная в этом 
Стандарте. 

пользовательское входное устройство: Устройство ввода данных, в настоящее 
время выбранное как источник получаемых данных, обычно клавиатура. 

пользовательское выходное устройство: Устройство вывода, в настоящее время 
выбранное как адресат выводимых данных. 

переменная: Именованная область данных расположенная и доступная по ее адресу 

памяти. 

слово: В зависимости от контекста: 

1) имя Рогіііі определения; или 

2) анализируемая непрерывная последовательность символов, которая могла 
быть именем РогСй определения. 

список слов: Список связанных имен Рогій определений, который может быть 
исследован во время поиска в словаре. 

набор слов: Набор определений Рогій, сгруппированных вместе в этом Стандарте 
под именем, указывающим на некоторые общие свойства, типично их общая область 
функционирования. 


2.2 


Нотация 



2 . 2.1 


Числовая Нотация 

Если иначе не определено, все ссылки к числам относятся к знаковым целым числам 
одна-ячейка. Диапазон значений величин показывается как {от... до}. Допустимый 
диапазон для содержимого адреса показывается в двойных фигурных скобках, 
особенно для содержимого переменных, например, ВАЗЕ {{2... 36}}. 

2 . 2.2 _ 

Стековая нотация 

Входные и выходные параметры стековых определений описаны, с использованием 
следующей нотации: 

( зіаск-ісі ЬеТоге -- аТГег ) 

Где зіаск-ісі определяет, какой стек описывается, Ье'Гоге представляет типы 
данных параметров стека перед выполнением определения и аТГег представляет их 
после выполнения. Символы, используемые в Ье'Гоге и аТГег показаны в таблице 

3.1. 

ЗГаск-ісІ стека потока-управления - "С:", зіаск-ісі стека данных - "5:", и зГаск- 
ісі стека возвратов - "Р?:". В случае отсутствия противоречий, зіаск-ісі стека 
данных, может быть опущен. 

Когда есть альтернативные варианты представления аТГег, они описаны как "аТГегІ 
| аТ1:ег2". Вершина стека - справа. Показываются только те элементы, которые 
требуются для выполнения или предоставляются в результате выполнения 
определения. 
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2.2.3 _ 

Нотации анализа текста 

Если, кроме использования параметров стека, определение анализирует текст, то 
этот текст обозначенный сокращением из таблицы 2.1, показывается окруженным 
двойными кавычками и помещается между Ье'Гоге параметрами и разделителем в 
первом описанном стеке, Например: 

(5: Ье'Гоге "аббревиатура анализируемого текста" - аТГег). 


Таблица 2.1 - сокращения анализатора текста 
Сокращение Описание 


<сЬаг> 

<сЬагз> 

<зрасе> 

<зрасез> 

<циоГе> 

<рагеп> 

<ео1> 

ссс 

пате 


символ ограничитель, отмечающий конец анализируемой строки 
ноль или более последовательно расположенных символов сЬаг 
символ ограничитель - пробел 

ноль или более последовательно расположенных символов зрасе 
символ ограничитель - двойная кавычка 
символ ограничитель - правая круглая скобка 
подразумеваемый ограничитель, отмечающий конец строки 
анализируемая последовательность произвольных символов, 
исключая символ ограничитель 

обозначение ограниченное пробелом, эквивалент ссс<зрасе> или 
ссс<ео1> 


2.2.4 


Словарные нотации 





Словарные входы для каждого набора слов представлены стандартными А5СІІ 

последовательностями. Каждый вход словаря определяет А№ РогТТі слово и состоит 

из двух частей: индексной строки и семантического описания определения. 

2.2.4.1 _ 

Индексная строка словаря 

Индексная строка - однострочный вход содержащий, слева направо: 

- Номер раздела, последние четыре цифры которого определяют уникальный 
последовательный номер для всех слов, включенных в этот Стандарт; 

- ИМЯ-ОПРЕДЕЛЕНИЯ в верхнем регистре, фиксированной ширины, символы жирного 
начертания; 

- Произношение на естественном языке в кавычках, если оно отличается от 
Английского языка; 

- Обозначение набора слов из таблицы 2.2. Обозначение для расширения набора 
слов включает "ЕХТ". 


Таблица 2.2 - Обозначения наборов слов 
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Набор слов 

Обозначение 

Базовый набор слов 

СОРЕ 

Блочный набор слов 

В1_0СК 

Набор слов двойных чисел 

001ІВІ_Е 

Набор слов исключений 

ЕХСЕРТІОМ 

Сервисный набор слов 

РАСІІЛТѴ 

Набор слов доступа к файлу 

РНЕ 

Набор слов для плавающей точки 

РБОАТІИС 

І_осаІ5 набор слов 

І_0САІ_5 

Набор слов распределения памяти 

МЕМОРУ 

Набор слов утилит 

Т00Ц5 

Набор слов порядка поиска 

5ЕАРСН 

Набор слов обработки строк 

ЗТРПб 


2 . 2 . 4.2 _ 

Семантическое описание словаря 

Первый параграф семантического описания содержит стековую нотацию для каждого 
стека, задействованного выполняемым словом. Остальные параграфы содержат 
текстовое описание семантики. Смотри 3.4.3 Семантика. 

2.3 _ 

Ссылки 

Следующие национальные и международные стандарты упомянуты в этом Стандарте: 

А№1 ХЗ.172-1990, ОісТіопагу Тог іпТогтаТіоп зузТетз (2.1 Определения 
терминов); 

А№1 ХЗ.4-1974, Атегісап ЗТапсІагсІ Сосіе Тог ІпТогтаТіоп ІпТегсТіапде (А5СІІ) 
(3.1.2.1 Графические символы); 

150 646-1983, 150 7-ЬіТ сосіесі сТіагасТегзеТ Тог ІпТогтаТіоп ІпТегсТіапде, 
ІпТегпаТіопаІ РеТегепсе Ѵегзіоп (ІРѴ) (3.1.2.1 Графические символы); 


АМ5І/ІЕЕЕ 754-1985, РІоаТіпд-роіпТ ЗТапсІагсІ (12.2.1 Определения 
терминов) . 
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3. _ 

Условия применения 

Система должна предоставлять все слова, определенные в 6.1 Основные слова. Она 
также может предоставлять любые слова, определенные в дополнительных и 
расширенных наборах слов. Никакое стандартное слово предоставленное системой не 
должно изменять состояние системы способом, изменяющим эффект выполнения любого 
другого стандартного слова, иным чем предусмотрено в этом Стандарте. Система 
может содержать не стандартные расширения предусмотренного здесь, при условии, 
что они совместимы с требованиями этого Стандарта. 

Реализация слов и методов могущих использоваться в системе вне области 
рассмотрения этого Стандарта. 

Система не требует предоставления всех слов в выполняемой форме. Реализация 
может предоставлять определения, включая определения Основного набора слов, 
только в исходной форме. Если так, то механизм для добавления определений в 
словарь - определяемый реализацией. 

Программа, которая требует, чтобы система предоставила слова или методы, не 
определенные в этом Стандарте является зависимой от окружения. 

3.1 _ 

Типы данных 

Тип данных идентифицирует набор допустимых значений для объекта данных. Это - 
не свойство конкретного местоположения в памяти или позиции на стеке. 
Перемещение объекта данных не будет затрагивать его тип. 

Система не требует никакой проверки типа данных. Неопределенная ситуация 
существует, если встречается неправильно определенный тип объекта данных. 

Таблица 3.1 суммирует типы данных, используемые везде в этом Стандарте. 
Множественные варианты одного и того же типа данных, в обозначении определения 
обозначены последовательными цифровыми сносками, для их различения. 

3.1.1 _ 

Отношения типов данных 

Некоторые из типов данных - подтипы других типов данных. Тип данных і - подтип 
типа і, если и только если члены і - подмножество членов д . Следующий список 
представляет отношения подтипов, используя фразу "і = > д" чтобы обозначить, 
что "і является подтипом д". Отношения подтипа транзитивны; если і = > ] и ] = 
> к , тогда і = > к: 

+п => и => х; 

+п => п => х; 
сбаг => +п; 

а-асісіг => с-асісіг => асісіг => и; 

Тіад => х; 


2Ѳ 


хі => х; 

+сІ => сі => хсі; 
+сІ => исі => хсі. 


Любое определение Рогбб, которое принимает параметр типа і должно также принять 
параметр являющийся подтипом і. 



3.1.2 


Символьные типы 


Символы должны быть, по крайней мере, шириной в один адресуемый элемент, 
содержать по крайней мере восемь бит, и иметь размер меньше чем или равный 
размеру ячейки. 

Символы, предоставленные системой должны включать графические символы 
{32..126}, которые представляют графические формы, показанные в таблице 3.2. 

3.1.2.1 _ 

Графические символы 

Графический символ является обычным отображаемым символом (например, А, #, &, 
6). Эти значения и графические формы, показанные в таблице 3.2, приняты 
непосредственно от АІ\І5 ХЗ.4-1974 (А5СІІ) и 150 646-1983, ІпГегпаІіопаІ 
РеТегепсе Ѵегзіоп (ІРѴ). Графические формы символов вне бех диапазона {2Ѳ.. 7Е} 
- зависящие от реализации. Программы, использующие графический символ бех 24 
(знак валюты) имеют зависимость от окружения. 

Графическое представление символов не ограничено специфическим типом или стилем 
шрифта. Графика здесь это пример. 

3.1.2.2 _ 

Управляющие символы 

Все неграфические символы, включенные в определенный-реализацией набор символов 
определены в этом Стандарт как управляющие символы. В частности символы {Ѳ.. 
31}, которые могли быть включены в определенный-реализацией набор символов - 
управляющие символы. 

Программы, которые требуют возможность посылать, или принимать управляющие 
символы имеют зависимость от окружения. 


Таблица 3.1 - Типы данных 

Символ Тип данных Размер на стеке 


-Гіад 

флаг 

1 ячейка 

Ігие 

флаг истина 

1 ячейка 

Таізе 

флаг ложь 

1 ячейка 

сбаг 

символ 

1 ячейка 

п 

число со знаком 

1 ячейка 

+п 

не отрицательное число 

1 ячейка 

и 

без знаковое число 

1 ячейка 
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п|и (1) 

ЧИСЛО 

1 

ячейка 

X 

любая ячейка 

1 

ячейка 

ХІ 

идентификатор исполнения 

1 

ячейка 

асісіг 

адрес 

1 

ячейка 

а-асісіг 

выровненный адрес 

1 

ячейка 

с-асібг 

символьно-выровненный адрес 

1 

ячейка 

СІ 

число со знаком две-ячейки 

2 

ячейки 

+6 

не отрицат. число две-ячейки 

2 

ячейки 

и с! 

беззнаковое число две-ячейки 

2 

ячейки 

сІ | исі (2) 

число две-ячейки 

2 

ячейки 

X СІ 

любая пара ячеек 

2 

ячейки 

соіоп-зуз 

компиляция определения 

определяемое 

сіо-зуз 

сіо-іоор структуры 

определяемое 

сазе-зуз 

САЗЕ структуры 

определяемое 


реализацией 

реализацией 

реализацией 




сгР-зуз 

огід 

без! 

Іоор-зуз 

пезі-зуз 

і*х, д*х, к*х (3) 


ОР структуры 

источник потока-управления 
назначение потока-управления 
Іоор-сопбгоі параметры 
вызовы определения 
любой тип данных 


определяемое реализацией 
определяемое реализацией 
определяемое реализацией 
определяемое реализацией 
определяемое реализацией 
0 или более ячеек 


(1) Может быть число со знаком или без знака в зависимости от контекста. 

(2) Может быть две-ячейки число со знаком или две-ячейки число без знака в 
зависимости от контекста. 

(3) Может быть неопределенное число входов стека неопределенного типа. Для 
примеров использования, см. 6.1.1370 ЕХЕСІІТЕ, 6.1.2050 ЦІІІТ. 


Таблица 3.2 - Стандартные графические символы 


Нех 

ІРѴ 

АЗСІ 

Нех 

ІРѴ 

А5СІ 

Нех 

ІРѴ 

АЗСІ 

Нех 

ІРѴ 

АЗСІ 

Нех 

ІРѴ 

АЗСІ 

Нех 

ІРѴ 

АЗСІ 

20 



30 

0 

0 

40 

@ 

§ 

50 

Р 

Р 

60 

' 

' 

70 

Р 

Р 

21 

! 

! 

31 

1 

1 

41 

А 

А 

51 

<2 

<2 

61 

а 

а 

71 

Ч 

Ч 

22 

II 

II 

32 

2 

2 

42 

В 

В 

52 

Р 

Р 

62 

Ь 

Ь 

72 

г 

г 

23 

# 

# 

33 

3 

3 

43 

С 

С 

53 

5 

5 

63 

с 

с 

73 

5 

5 

24 

- 

$ 

34 

4 

4 

44 

О 

О 

54 

Т 

Т 

64 

б 

б 

74 

X. 

X 

25 

% 

% 

35 

5 

5 

45 

Е 

Е 

55 

ц 

11 

65 

е 

е 

75 

и 

и 

26 

& 

& 

36 

6 

6 

46 

Р 

Р 

56 

V 

V 

66 

Г 

Г 

76 

V 

V 

27 

1 

1 

37 

7 

7 

47 

6 

6 

57 

VI 

VI 

67 

9 

9 

77 

И 

И 

28 

( 

( 

38 

8 

8 

48 

Н 

Н 

58 

X 

X 

68 

и 

И 

78 

X 

X 

29 

) 

) 

39 

9 

9 

49 

I 

I 

59 

У 

У 

69 

і 

і 

79 

У 

У 

2А 

к 

к 

ЗА 



4А 

3 

3 

5А 

2 

2 

6А 

3 

3 

7А 

2 

2 

2В 

+ 

+ 

ЗВ 

А 

А 

4В 

к 

к 

5В 

[ 

[ 

6В 

к 

к 

7В 

{ 

{ 

2С 

А 

А 

ЗС 

< 

< 

4С 

|_ 

|_ 

5С 

\ 

\ 

6С 

1 

1 

7С 

1 

1 

2Р 

- 

- 

ЗО 

~ 

= 

4Р 

м 

м 

50 

] 

] 

60 

ш 

ш 

70 

} 

} 

2Е 



ЗЕ 

> 

> 

4Е 

N 

N 

5Е 

А 

А 

6Е 

п 

п 

7Е 

- 

- 

2Р 

/ 

/ 

ЗР 

? 

? 

4Р 

0 

0 

5Р 



6Р 

О 

о 
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Определенный-реализацией фиксированный размер ячейки определен адресуемыми 
элементами и соответствующим количеством бит. См. Е.2 Аппаратные особенности. 

Ячейки должны быть, по крайней мере, размером в один адресуемый элемент, и 
содержать, по крайней мере, 16-бит. Размер ячейки должен быть кратным целым 
размера символа. Элементы стека данных, элементы стека возвратов, адреса, 
идентификаторы исполнения, флаги, и целые числа - размером в одну ячейку. 

3.1.3.1 _ 

Флаги 

Флаги могут иметь одно из двух логических значений: Ігие или Таізе . Программы, 
которые используют флаги как арифметические операнды, имеют зависимость от 
окружения. 

Тше флаг, возвращенный стандартным словом должен иметь значение одна-ячейка со 
всеми установленными битами. А баізе флаг, возвращенный стандартным словом 
должен иметь значение одна-ячейка со всеми сброшенными битами. 

3.1.3.2 _ 

Целые числа 


Определенный реализацией диапазон целых чисел со знаком должен включать {- 
32767.. +32767}. 






Определенный реализацией диапазон неотрицательных целых чисел должен включать 
{Ѳ. . 32767} . 

Определенный реализацией диапазон целых чисел без знака должен включать {0.. 
65535}. 

3.1.3.3 _ 

Адреса 

Адрес идентифицирует местоположение в области данных с размером одного 
адресуемого элемента, который программа может выбирать из памяти или заносить в 
память, кроме ограничений, установленных в этом Стандарте. Размер адресуемого 
элемента определен в битах. Каждое отличное значение адреса идентифицирует 
точно один такой запоминающий элемент. См. 3.3.3 Область данных. 

Набор символьно-выровненных адресов, адреса которыми можно обращаться к символу 
- определенное-реализацией подмножество всех адресов. Добавление размера 
символа к символьно-выровненному адресу должно произвести другой символьно- 
выровненный адрес. 

Набор выровненных адресов - определенное-реализацией подмножество символьно- 
выровненных адресов. Добавление размера ячейки к выровненному адресу должно 
произвести другой выровненный адрес. 

3.1.3.4 _ 

Строки со счетчиком 

Строка со счетчиком в памяти идентифицирована адресом (с-асісіг)символа её длины. 

Символ длины строки со счетчиком должен содержать число символов данных 
двоичного представления, между нулем и определенной-реализацией максимальной 
длиной для строки со счетчиком. Максимальная длина строки со счетчиком должна 
быть, по крайней мере, 255. 
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3.1.3.5 _ 

Идентификаторы исполнения 

Различные определения могут иметь один и тот же идентификатор исполнения, если 
определения эквивалентны. 

3.1.4 _ 

Типы пара-ячеек 

Пара-ячеек в памяти состоит из последовательности двух непрерывных ячеек. 

Ячейка с меньшим адресом - первая ячейка, и её адрес используется, для 
идентификации пары ячеек. Если иначе не определено, пара ячеек на стеке состоит 
из первой ячейки непосредственно выше второй ячейки. 

3.1.4.1 _ 

Целые числа две-ячейки 

На стеке, ячейка содержащая самую старшую часть целого числа две-ячейки должна 
быть выше ячейки содержащей самую младшую часть. 

Определенный-реализацией диапазон целых чисел две-ячейки со знаком должен 
включать {-2147483647..+2147483647}. 


Определенный-реализацией диапазон не отрицательных целых две-ячейки чисел 
должен включать {0..2147483647}. 



Определенный-реализацией диапазон без знаковых целых чисел две-ячейки должен 
включать {0..4294967295}. Размещение нулевого целого числа одна-ячейка на стеке 
выше целого числа одна-ячейка без знака производит целое число две-ячейки без 
знака с тем же самым значением. См. 3.2.1.1 Внутреннее представление числа. 

3.1.4.2 _ 

Символьные строки 

Строка определенная как пара ячеек (с-асісіг и) представляет её стартовый адрес и 
длину в символах. 


Системные типы 

Системные типы данных определяют допустимые комбинации слов в течение 
компиляции и выполнения. 

3.1.5.1 _ 

Системные типы компиляции 

Эти типы данных обозначают нуль или большее количество элементов на стеке 
потока-управления (см. 3.2.3.2). Возможное присутствие таких элементов на стеке 
данных означает, что любые элементы уже там находящиеся должны быть недоступны 
программе, пока не использованы элементы стека потока-управления. 

Зависящие-от-реализации данные, сгенерированные после начала компиляции 
определения и использованные при его завершении обозначены символом соіоп-зуз 
повсюду этом Стандарте. 

Зависящие-от-реализации данные, сгенерированные после начала компиляции сіо-іоор 
структуры типа ЭО ... 1_00Р и использованные при её завершении обозначены 
символом сіо-зуз повсюду этом Стандарте. 
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Зависящие-от-реализации данные, сгенерированные после начала компиляции САЗЕ 
... ЕШСА5Е структуры и использованные при её завершении обозначены символом 
сазе-зуз повсюду этом Стандарте. 

Зависящие-от-реализации данные, сгенерированные после начала компиляции ОР ... 
ЕШОР структуры и использованные при её завершении обозначены символом о'Р-зуз 
повсюду этом Стандарте. 

Зависящие-от-реализации данные, сгенерированные и использованные при выполнении 
другого стандартного слова потока-управления обозначены символами огід и сіезі; 
повсюду в этом Стандарте. 

3.1.5.2 _ 

Системные типы выполнения 

Эти типы данных обозначают нуль или большее количество элементов на стеке 
возвратов. Их возможное присутствие означает, что любые элементы на стеке 
возвратов уже должны быть недоступны программе, пока элементы системных типов 
выполнения не использованы. 

Зависящие-от-реализации данные, сгенерированные после начала выполнения 
определения и использованные после выхода из него обозначены символом пезі-зуз 
повсюду в этом Стандарте. 

Зависящие-от-реализации параметры Іоор-сопігоі используемые для управления 
выполнением сіо-іоорз обозначены символом Іоор-зуз повсюду в этом Стандарте. 
І_оор-соп1:го1 параметры должны быть доступны внутри сіо-іоор для слов, которые 
используют или изменяют эти параметры, слова типа I, Э, І_ЕАѴЕ и ІІІ\ІІ_ООР. 



3.2 _ 

Среда выполнения 

3.2.1 _ 

Числа 

3.2.1.1 _ 

Внутреннее представление числа 

Этот Стандарт допускает представления чисел и арифметические операции с 
обратным кодом (дополнение до единицы), с дополнительным кодом (дополнение до 
двух), или величин со знаком. Арифметический нуль представлен как значение 
одна-ячейка со всеми сброшенными битами. 

Представление числа как скомпилированного литерала или в памяти - зависящее от 
реализации. 

3.2.1.2 _ 

Преобразование цифр 

Числа должны быть представлены внешне с использованием символов из стандартного 
набора символов. 

Преобразование между внутренними и внешними формами цифры должно производиться 
следующим образом: 

Значение в ВАЗЕ - основание системы счисления для преобразования чисел. Цифра 
имеет значение в пределах от нуля до на единицу меньшего содержимого ВАЗЕ. 

Цифра с нулевым значением соответствует символу "Ѳ" . Это представление цифр 
продолжается по набору символов до десятичного значения девять соответствующему 
символу "9". Для цифр начинающихся с десятичного значения десять используются 
графические символы начинающиеся с символа "А". 
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Это соответствие продолжается вплоть до, и включая цифру с десятичным значением 
тридцать пять, которая представляется символом "2". Преобразование цифр вне 
этого диапазона - определенное реализацией. 

3.2.1.3 _ 

Изображение чисел в свободном поле 

Изображение чисел в свободном поле использует символы, описанные в 
Преобразовании цифр, без предшествующих нулей, в поле точно по размеру 
преобразованной строки плюс конечный пробел. Если число нулевое, наименьшая 
значащая цифра не рассматривается как начальный ноль. Если число отрицательное, 
отображается ведущий знак "минус". 

Изображение чисел может использовать буфер выходной строки отображаемого числа, 
для хранения частично преобразованных строк (см. 3.3.3.6 Другие временные 
области). 

3.2.2 _ 

Арифметика 

3.2.2.1 _ 

Целочисленное деление 


Деление производит частное ц и остаток г, деля операнд а на операнд Ь. Операции 
деления возвращают ц, г, или оба. Тождество Ь * ц + г = а должно сохраняться 
для всех а и Ь. 



Когда делятся целые числа без знака, и остаток - не нулевой, ц - самое большее 
целое число меньше чем истинное частное. 


Когда делятся целые числа со знаком, и остаток - не нулевой, и а и Ь имеют 
одинаковый знак, ц - самое большее целое число меньше чем истинное частное. 

Если только один операнд отрицательный, округлено ли ц к отрицательной 
бесконечности (минимальное деление) или округлено к нулю (симметричное деление) 
- определенное реализацией. 

Минимальное деление - целочисленное деление, в котором остаток имеет знак 
делителя или нулевой, и частное округлено к его арифметическому минимуму. 
Симметричное деление - целочисленное деление, в котором остаток имеет знак 
делимого или нуль и частное - математическое частное "округленное к нулю" или 
"обрезанное". Примеры каждого показаны в таблицах 3.3 и 3.4. 

В случаях, где операнды отличаются по знаку и в вопросе направления округления, 
программа должна или включать код, генерирующий желательную форму деления, не 
полагаясь на результат по умолчанию определенный реализацией, или иметь 
зависимость от окружения желательного направления округления. 


Таблица 3, 

, 3 - Пример 

минимального 

деления 

Делимое 

Делитель 

Остаток 

Частное 

10 

7 

3 

1 

-10 

7 

4 

-2 

10 

-7 

-4 

-2 

-10 

-7 

-3 

1 


Таблица 3, 

,4 - Пример 

симметричного деления 

Делимое 

Делитель 

Остаток 

Частное 

10 

7 

3 

1 

-10 

7 

-3 

-1 

10 

-7 

3 

-1 

-10 

-7 

-3 

1 


3.2.2.2 _ 

Другие целочисленные операции 

Во всех целочисленных арифметических операциях переполнение и антипереполнение 
должны игнорироваться. Возвращаемое значение, когда происходит переполнение или 
антипереполнение - определенное реализацией. 

3.2.3 _ 

Стеки 

3.2.3.1 _ 

Стек Данных 

Объекты на стеке данных должны быть шириной в одну ячейку. 

3.2.3.2 _ 

Стек потока-управления 

Стек потока-управления - это список типа "последним пришел", "первым вышел", 







чьи элементы определяют допустимые соответствия слов потока-управления и 
ограничения, наложенные на использование стека данных в течение компиляции 
управляющих структур. 

Элементы стека потока-управления - системные типы данных компиляции. 

Стек потока-управления, может, но не обязательно, физически существовать в 
реализации. Если он существует, то может быть, но не обязательно, реализован с 
использованием стека данных. Формат стека потока-управления - определяется 
реализацией. Так как стек потока-управления может быть реализован с 
использованием стека данных, элементы, помещенные на стек данных недоступны для 
программ после помещения элементов на стек потока-управления, и остаются 
недоступным до удаления элементов стека потока-управления. 

3.2.3.3 _ 

Стек возвратов 

Элементы на стеке возвратов должны состоять из одной или более ячеек. Система 
может использовать стек возвратов зависящим от реализации способом в течение 
компиляции определений, в течение выполнения сіо-іоорз, и для сохранения 
вложенной информации во время выполнения. 

Программа может использовать стек возвратов как временную память в течение 
выполнения определения, подчиняясь следующим ограничениям: 

- Программа не должна обращаться к значениям на стеке возвратов (используя Р@, 
П>, 2П@ или 2П>) для элементов, не размещенных туда с помощью >П или 2>П; 

- Программа не должна обращаться изнутри сіо-іоор к значениям, помещенным на 
стек возвратов прежде, чем был открыт цикл; 
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- Все значения, помещенные на стек возвратов в пределах сіо-іоор должны быть 
удалены прежде, чем будут выполнены I, Э, 1_00Р, +ЮОР, ІІІ\ІІ_ООР, или І_ЕАѴЕ ; 

- Все значения, помещенные на стек возвратов в пределах определения должны быть 
удалены перед тем, как определение будет закончено или прежде, чем будет 
выполнен ЕХІТ . 

3.2.4 _ 

Терминал Оператора 

См. 1.2.2 Исключения. 

3.2.4.1 _ 

Пользовательское устройство ввода 

Метод выбора пользовательского устройства ввода данных - определенный 
реализацией. 

Метод индикации конца входной строки текста - определенный реализацией. 

3.2.4.2 _ 

Пользовательское устройство вывода 

Метод выбора пользовательского устройства вывода - определенный реализацией. 

3.2.5 _ 

Запоминающее устройство большой емкости 

Система не предусматривает какие либо стандартные слова для доступа к 
запоминающему устройству большой емкости. Если система предоставляет какое либо 
стандартное слово для доступа к запоминающему устройству большой емкости, она 
должна также дополнить Блочный набор слов. 



3.2.6 


Запросы к окружению 


Пространства имен для ЕІМѴІРОММЕМТ? и определений непересекающиеся. Названия 
определений являющиеся такими же как ЕІ\ІѴІРСШМЕІ\ІТ? строки не должны мешать 
операции ЕМѴІРОММЕМТ? . 

Таблица 3.5 содержит допустимые входные строки и соответствующие возвращаемые 
значения для запросов к программной среде с помощью ЕІМѴІРОММЕІМТ? . 


Таблица 3.5 - Строки запросов к окружению 


Строка 

Тип 

Константа Значение 

/С01ІМТЕ0-5ТПІМ6 

п 

уез 

максимальный размер строки со счетчиком, в 
символах 

/НОбО 

п 

уез 

размер буфера выходной строки отображаемого 
числа, в символах 

/РАО 

п 

уез 

размер рабочей области, указываемой РАО, в 
символах 

А00ВЕ55-ІШТ-ВІТ5 

п 

уез 

размер одного адресуемого элемента, в битах 

СОРЕ 

Тіад 

по 

Тгие если присутствует полный основной набор 
слов 

(то есть, не подмножество как определено в 
5.1.1) 

СОРЕ-ЕХТ 

Тіад 

по 

Тше если присутствует расширенный набор слов 

РЮОРЕО 

Тіад 

уез 

Тше если минимальное деление по умолчанию 

МАХ-СНАР 

и 

уез 

максимальное значение какого либо символа в 
наборе символов определенном реализацией 
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МАХ-0 

СІ 

уез 

наибольшее используемое знаковое двойное 
число 

МАХ-М 

п 

уез 

наибольшее используемое знаковое число 

МАХ-11 

и 

уез 

наибольшее используемое без знаковое число 

МАХ -ІЮ 

иб 

уез 

наибольшее используемое без знаковое двойное 
число 

РЕТІІРІМ-ЗТАСК-СЕШЗ 

п 

уез 

максимальный размер стека возвратов, в 
ячейках 

5ТАСК-СЕШ5 

п 

уез 

максимальный размер стека данных, в ячейках 


Если запрос к окружению (с помощью ЕІМѴІРСШМЕІМТ?) возвращает Таізе (то есть, 
неизвестное) в ответ на строку, последующие запросы, использующие ту же самую 
строку могут возвратить Тше. Если запрос возвращает Тше (то есть, известный) 
в ответ на строку, последующие запросы с той же самой строкой должны также 
возвращать Тше. Если запрос, обозначенный как константа в вышеупомянутой 
таблице, возвращает Тше и значение в ответ на строку, последующие запросы с 
той же самой строкой должны возвратить Іше и то же самое значение. 

3.3 _ 

Словарь РогТб 

Слова РогТб организованы в структуру называемую словарем. В то время как форма 
этой структуры не определена Стандартом, она может быть описана как состоящая 
из тех логических частей: области имени, области кода, и области данных. 
Логическое разделение этих частей не требует их физического разделения. 

Программа не должна брать или сохранять данные в место вне области данных. 
Неоднозначное условие существует, если программа адресует область имени или 
область кода. 





3.3.1 


Область имени 

Отношения между областью имени и областью данных - зависящие от реализации. 

Структура списка слов - зависящая от реализации. Когда в списке слов существуют 
дубликаты имен, в процессе поиска имени должен быть найден последний 
определенный дубликат. 

3.3.1.2 _ 

Имена определений 

Имена определений должны содержать {1.. 31} символов. Система может позволять 
или запрещать создание имен определений, содержащих не стандартные символы. 

Программы, которые используют строчные буквы для стандартных имен определений 
или зависят от регистро-чувствительных свойств системы - имеют зависимость от 
окружения. 

Программа не должна создавать имена определений, содержащие неграфические 
символы. 

3.3.2 _ 

Область кода 

Отношения между областью кода и областью данных - зависящие от реализации. 
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3 . 3.3 _ 

Область данных 

Область данных - единственная логическая область словаря, для которой 
предусмотрены стандартные слова, для того чтобы распределять и обращаться к 
областям памяти. Этими областями являются: непрерывные области, переменные, 
области текстовых констант, буферы ввода, и другие временные области, каждая из 
которых описана в следующих разделах. Программа может читать из или записывать 
в эти области, если иначе не определено. 

3.3.3.1 _ 

Выравнивание адреса 

Большинство адресов, используемых в А№ Рогій это выровненные адреса 
(обозначены - а-асісіг) или символьно-выровненные (обозначены с-асісіг). АІЛ6МЕР, 
СНАП+, и арифметические операции могут изменять состояние выравнивания адреса 
на стеке. СНАР+ применяемое к выровненным адресам возвращает символьно- 
выровненные адреса, которые могут использоваться только, для обращения к 
символам. Применение СНАП+ к символьно-выровненному адресу производит следующий 
символьно-выровненный адрес. Добавление или вычитание произвольного числа к 
адресу может производить не выровненный адрес, который не может быть 
использован для выборки или сохранения чего-нибудь. Единственный путь найти 
следующий выровненный адреса - это АІЛСМЕР. Неопределенная ситуация существует 
когда §, !, , (запятая), +!, 2@, ог 2! используется с адресом, который не 
выровнен, или когда С@, С!, или С, используется с адресом, который не 
символьно-выровненный . 

Определения 6.1.1000 СНЕАТЕ и 6.1.2410 ѴАРІАВБЕ требуют, чтобы определения 
созданные ими возвращали выровненные адреса. 


После того, как определения откомпилированы, или выполнено слово АІЛ6ІМ, 
указатель области данных гарантировано будет выровненным. 



3.3.3.2 _ 

Непрерывные области 

Система гарантирует, что зона области данных распределенная с использованием 
АШОТ, , (запятая) , С, (с-запятая) , и АІЛСІМ, будет неразрывна с предыдущей 
зоной, распределенной одним из вышеупомянутых слов, если не применяются 
ограничения из следующих параграфов. Указатель области данных НЕКЕ всегда 
идентифицирует начало следующей зоны области данных, которая будет 
распределена. Как только последовательные распределения сделаны, увеличивается 
указатель области данных. Программа может исполнять адресную арифметику в 
пределах непрерывно распределенной области. Последняя зона области данных 
распределенная с использованием вышеупомянутых операторов может быть 
освобождена, распределением соответствующей зоны отрицательного размера, 
используя АШОТ, с соблюдением ограничений следующих параграфов. 

СПЕАТЕ устанавливает начало непрерывной зоны области данных, чей стартовый 
адрес возвращен созданным СРЕАТЕ определением. Эта зона заканчивается, 
компиляцией следующего определения. 

Так как реализация не накладывает ограничений на распределение области данных 
для использования кодом, вышеупомянутые операторы не обязаны производить 
непрерывные зоны области данных, если между распределениями были добавлены или 
удаленны из словаря определения. Неопределенная ситуация существует если 
освобожденная память содержит определения. 

3.3.3.3 _ 

Переменные 
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Область, распределенная для переменной может состоять из нескольких несмежных 
участков с областями впоследствии распределенными с помощью , (запятая) или 
АШОТ. Например, в: 

ѴАРІАВЦЕ X 1 СЕШ5 АШОТ 

зона X и распределенная АШОТ зона могут быть несмежными. 

Некоторые поставляемые-системой переменные, типа 5ТАТЕ, ограничены доступом 
только для чтения. 

3.3.3.4 _ 

Области текстовых констант 

Области текстовых констант, заданные строками, откомпилированными с помощью 5" 
и С", могут быть только-для-чтения. 

Программа не должна сохранять в областях текстовых констант созданных с помощью 
5" и С", ни в другие только-для-чтения системные переменные или только-для- 
чтения временные области. Неопределенная ситуация существует когда программа 
пытается сохранять в области только-для-чтения. 

3.3.3.5 _ 

Входные буферы 

Адрес, длина, и содержание входного буфера могут быть временными. Программа не 
должна записывать во входной буфер. В отсутствии каких либо дополнительных 
наборов слов предусматривающих альтернативные входные источники, входной буфер 
- это либо входной буфер терминала, используемый фШТ для хранения одной строки 
из пользовательского устройства ввода данных, либо буфер определяемый ЕѴАШІАТЕ. 
Во всех случаях 501ІРСЕ возвращает начальный адрес и длину в символах текущего 
входного буфера. 



Минимальный размер входного буфера терминала должен быть 8Ѳ символов. 

Адрес и длина возвращенная 501ІРСЕ, строки возвращенной РАР5Е, и непосредственно 
вычисленный адрес входного буфера имеют силу только пока текстовый 
интерпретатор не делает ввод-вывод для наполнения входного буфера, или не 
изменен входной источник. 

Программа может изменять размер области анализа, изменяя содержимое >ІІМ в 
пределах ограничений, наложенных этим Стандартом. Например, если содержимое >ІІ\І 
сохранено перед операцией анализа и восстановлено впоследствии, текст, который 
анализировался, будет доступен снова для последующих операций синтаксического 
анализа. Степень допустимого повторного позиционирования с использованием этого 
метода зависит от входного источника (см. 7.3.3 Области Блочного буфера и 
11.3.4 Входной источник). 

Программа может непосредственно исследовать входной буфер, используя его адрес 
и длину возвращенную 501ІРСЕ; начало области анализа в пределах входного буфера 
индексировано числом в >ІІ\]. Значения имеют силу на ограниченный срок. 
Неопределенная ситуация существует если программа изменяет содержимое входного 
буфера. 

3.3.3.6 _ 

Другие временные области 

Зоны области данных, идентифицированные РАР, МОКР, и #> (буфер выходной строки 
отображаемого числа) могут быть временными. Их адреса и содержание могут стать 
недействительными после того, как: 

- создано определение через определяющее слово; 
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- определения скомпилированы с помощью : или :І\ІОІ\ІАМЕ; 

- область данных выделена, с помощью АШОТ, , (запятая), С, (с-запятая), или 
АИ6М. 

Предыдущее содержание областей, идентифицированных МОКР и #> , может быть 
недействительно после каждого использования этих слов. Кроме того, области, 
возвращенные МОКР и #> , могут накладываться в памяти. Следовательно, 
использование одного из этих слов может разрушать область, возвращенную ранее 
другим словом. Другие слова, которые создают выходную строку отображаемого 
числа (<#, #, #5, и Н01_Р) могут также изменять содержание этих областей. Слова, 
которые выводят числа, могут быть реализованы с использованием слов вывода 
отображаемых чисел. Следовательно . (точка), .К, .5, ?, Р., Р.Р, II., и II. К 
могут также разрушать области. 

Размер рабочей области, чей адрес возвращен РАР, должен быть, по крайней мере, 
84 символа. Содержание области адресованной РАР предназначено, для того чтобы 
быть под полным контролем пользователя: никакие слова, определенные в этом 
Стандарте не помещают что-либо в эту область, также при изменении распределения 
области данных как описано в 3.3.3.2 непрерывная область может изменять адрес 
возвращаемый РАР. Нестандартные слова, предусмотренные реализацией, могут 
использовать РАР, но такое использование должно быть документировано. 

Размер области, идентифицированной МОКР должен быть, по крайней мере, 33 
символа. 

Размер буфера строки отображаемого числового вывода должен быть, по крайней 
мере, (2*п) + 2 символов, где п - число бит в ячейке. Программы, которые 
рассматривают её фиксированной областью с не изменяющимися параметрами доступа 

- имеют зависимость от окружения. 


3.4 



Интерпретатор текста Рогіб 


После запуска система должна иметь возможность интерпретировать, как описано в 
6.1.2Ѳ5Ѳ фШТ, РогііИ исходный текст полученный в интерактивном режиме из 
пользовательского устройства ввода данных. 

Такие интерактивные системы обычно предоставляют "приглашение", указывающее, 
что они принимают пользовательский запрос и действуют в соответствии с ним. 
Определенное реализацией приглашение Рогбб должно содержать слово "ОК" в 
некоторой комбинации верхних или строчных букв. 

Текстовая интерпретация (см. 6.1.136Ѳ ЕѴАШАТЕ и 6.1.2Ѳ5Ѳ фШТ) должна 
повторять последовательные шаги до опустения области анализа, или возникновения 
неопределенной ситуации: 

а) Пропустить ведущие пробелы и выделить имя (см. 3.4.1); 

б) Просмотреть область имен словаря (см. 3.4.2). Если имя определения, 
соответствующее строке найдено: 

1) при интерпретации, исполнить семантику интерпретации определения (см. 

3.4.3.2) , и продолжить с а); 

2) при компиляции, исполнить семантику компиляции определения (см. 

3.4.3.3) , и продолжить с а). 

в) Если имя определения, соответствующее строке не найдено, пытаться 
преобразовать строку в число (см. 3.4.1.3). Если успешно: 
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1) при интерпретации, положить число на стек данных, и продолжить с а); 

2) при компиляции, скомпилировать код, который при выполнении положит 
число на стек (см. 6.1.1780 І_ІТЕКАІ_), и продолжить с а); 

г) Если неудачно, существует неопределенная ситуация (см. 3.4.4). 

3.4.1 _ 

Синтаксический анализ 

Если иначе не отмечено, число анализируемых символов может быть от нуля до 
определенной реализацией максимальной длины строки со счетчиком. 

Если область анализа пуста, то есть когда число в >ІМ равно длине входного 
буфера, или не содержит других символов кроме разделителей, то выбранная строка 
пуста. Иначе, выбранная строка начинается со следующего символа в области 
анализа, который является символом, индексированным содержимым >ІМ. 
Неопределенная ситуация существует если число в >ІМ больше чем размер входного 
буфера. 

Если символы-разделители присутствуют в области анализа после начала выбранной 
строки, строка продолжается вплоть до символа как раз перед первым таким 
разделителем, и число в >ІМ изменяется, так чтобы указывать непосредственно 
после этого разделителя, таким способом удаляются анализируемые символы и 
разделитель из области анализа. Иначе, строка продолжается вплоть до последнего 
символа в области анализа, и число в >ІИ изменяется на длину входного буфера, 
таким способом освобождая область анализа. 

Синтаксический анализ может изменять содержимое >ІІ\І, но не должен затрагивать 
содержимое буфера ввода. В частности, если значение в >ІМ сохранено перед 
стартом анализа, возврат >ІМ к этому значению немедленно после анализа, должен 
восстановить область анализа без потери данных. 

3.4.1.1 _ 

Разделители 

Если разделитель - пробел (бех 20 (ВЦ)) управляющие символы могут быть 
интерпретированы как разделители. Набор условий, если таковые вообще имеются, 



согласно которым разделитель "пробел" соответствует управляющим символам - 
определенное реализацией. 


Для пропуска ведущих разделителей необходимо пропустить ноль или более смежных 
разделителей в области анализа перед синтаксическим анализом. 

3.4.1.2 _ 

Синтаксис 

РогИп имеет простой, операторно-упорядоченный синтаксис. Фраза АВС 
возвращает значения, как будто А было выполнено первым, затем В и наконец С. 
Слова, которые вызывают отклонения от этого линейного потока-управления, 
называются словами потока-управления. Структуры потока-управления - комбинации 
слов потока-управления, чьи стековые эффекты являются совместимой формой. 
Примеры типичного использования даны для каждого слова потока-управления в 
Приложении А. 

Синтаксис РогИп расширяем; например, в терминах существующих могут быть 
определены новые слова потока-управления. 

Этот Стандарт не требует синтаксиса или средств проверки структуры программы. 
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3.4.1.3 _ 

Преобразование входных чисел текстового интерпретатора 

При преобразовании входных чисел, текстовый интерпретатор должен распознавать 
положительные и отрицательные числа; отрицательные числа, представленные 
отдельным знаком "минус" (символом "-") предшествующим цифрам. Значение в ВАЗЕ 
- основание системы счисления для преобразования чисел. 

3.4.2 _ 

Поиск имен определений 

Строка соответствует имени определения, если каждый символ в строке 
соответствует соответствующему символу в строке, используемой как имя 
определения, когда определение было создано. Регистровая чувствительность 
(действительно ли символы верхнего регистра соответствуют символам нижнего 
регистра) - определенная реализацией. Система может быть либо чувствительной к 
регистру и трактовать символы верхнего - и нижнего регистра как различные и не 
соответствующие, либо нечувствительной к регистру, игнорируя различия в 
регистре при поиске. 

Соответствие символов верхнего - и нижнего регистра с алфавитными символами в 
расширенном наборе символов типа интернациональных символов с диакритическим 
знаком - определенное реализацией. 

Система должна быть способна к нахождению имен определений, определенных в этом 
Стандарте, когда они записаны символами в верхнем регистре. 

3.4.3 _ 

Семантика 

Семантика определения РогІН реализована машинным кодом или последовательностью 
идентификаторов исполнения или другими представлениями. Они в значительной 
степени определены стековой нотацией в словарных входах, которые показывают 
какие значения должны быть использованы и произведены. Проза в каждом входе 
словаря далее определяет поведение определения. 

Каждое определение РогИп может иметь несколько поведений, описанных в следующих 
разделах. Термины "семантика инициации" и "семантика времени-выполнения" 
относятся к фрагментам определения, и имеют значение только в пределах 



индивидуальных входов словаря, где они появляются. 

3.4.3.1 _ 

Семантика выполнения 

Семантика выполнения каждого определения РогІИ определена в секции 
"Выполнение:" его входа словаря. Когда определение имеет только одно указанное 
поведение, метка опущена. 

Выполнение может происходить неявно, когда выполняется определение, в которое 
оно было скомпилировано, или явно, когда его идентификатор исполнения 
передается в ЕХЕСІІТЕ. Семантика выполнения синтаксически правильного 
определения при условиях отличных от тех, что определены в этом Стандарте - 
зависящая от реализации. 

Входы словаря для определяющих слов включают семантику выполнения для нового 
определения в секции "имя Выполнение:". 

3.4.3.2 _ 

Семантика интерпретации 

Если иначе не определено в секции "Интерпретация:" входа словаря, семантика 
интерпретации определения Рогбб - это его семантика выполнения. 
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Система должна быть способна выполнить в состоянии интерпретации все 
определения из основного набора слов и любые определения, включенные в 
дополнительный набор слов или слова расширенного набора, чья семантика 
интерпретации определена в этом Стандарте. 

Система должна быть способна выполнить в состоянии интерпретации любые новые 
определения созданные в соответствии с 3. Условия применения. 

3.4.3.3 _ 

Семантика компиляции 

Если иначе не определено в секции "Компиляция:" входа словаря, семантика 
компиляции определения Рогбб должна добавить его семантику выполнения в конец 
семантики выполнения текущего определения. 

3.4.4 _ 

Возможное действие на неопределенную ситуацию 

Когда существует неопределенная ситуация, система может предпринимать одно или 
более из следующих действий: 

- игнорировать, и продолжить; 

- вывести сообщение; 

- выполнить специфическое слово; 

- установить состояние интерпретации и начать текстовую интерпретацию; 

- предпринимать другие действия определенные реализацией; 

- предпринимать зависящие от реализации действия. 

Ответ на специфическую неопределенную ситуацию не обязан быть один и тот же при 
всех обстоятельствах. 

3.4.5 _ 

Компиляция 

Программа не должна пытаться выполнять вложенную компиляцию определений. 


В течение компиляции текущего определения, программа не должна выполнять 



никакое определяющее слово, :І\ІСШАМЕ, или любое определение, которое 
распределяет область данных словаря. Компиляция текущего определения может быть 
приостановлена, с помощью [ (левая скобка) и продолжена, с помощью ] (правая 
скобка). Если компиляция текущего определения приостановлена, программа не 
должна выполнять никакое определяющее слово, :І\ІСШАМЕ, или любое определение, 
которое распределяет область данных словаря. 
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4. _ 

Документационные требования 

Когда невозможно или неосуществимо для системы или программы определить ее 
детали поведения, допустимо установить, что поведение - точно неопределяемое и 
объяснить обстоятельства и причины, почему это - так. 

4.1 _ 

Системная документация 

4.1.1 _ 

Опции определяемые реализацией 

В следующем списке пункты определенные реализацией представляют характеристики 
и варианты, оставленные на усмотрение разработчика, при условии, что выполнены 
требования этого Стандарта. Система должна документировать значения, или 
поведения, для каждого пункта. 

- требования к выравниванию адреса (3.1.3.3 Адреса); 

- поведение 6.1.1320 ЕМІТ для неграфических символов; 

- символьное редактирование 6.1.0695 АССЕРТ и 6.2.1390 ЕХРЕСТ; 

- набор символов (3.1.2 Символьные типы, 6.1.1320 ЕМІТ, 6.1.1750 КЕУ); 

- требования символьно-выровненного адреса (3.1.3.3 Адреса); 

- характеристики, соответствующие расширениям набора символов (3.4.2 Поиск 
имен определений); 

- условия, при которых управляющие символы соответствуют пробельному 
разделителю (3.4.1.1 Разделители); 

- формат стека потока-управления (3.2.3.2 Стек потока-управления); 

- преобразование цифр больших, чем тридцать пять (3.2.1.2 Преобразование цифр); 

- изображение после окончания ввода в 6.1.0695 АССЕРТ и 6.2.1390 ЕХРЕСТ; 

- последовательность сброса исключения (как в 6.1.0680 АБОРТ"); 

- признак конца входной строки (3.2.4.1 Пользовательское устройство ввода 
данных); 

- максимальный размер строки со счетчиком, в символах (3.1.3.4 Строки со 
счетчиком, 6.1.2450 МОНО); 

- максимальный размер анализируемой строки (3.4.1 Синтаксический анализ); 

- максимальный размер имени определения, в символах (3.3.1.2 Имена 
определений); 

- максимальная длина строки для 6.1.1345 ЕІМѴІРОММЕІМТ?, в символах; 

- метод выбора 3.2.4.1 Пользовательское устройство ввода; 

- метод выбора 3.2.4.2 Пользовательское устройство вывода; 

- методы компиляции словаря (3.3 Словарь РогІП); 

- число бит в одном адресуемом элементе (3.1.3.3 Адреса); 

- представление числа и арифметика (3.2.1.1 Внутреннее представление числа); 

- диапазоны для п, +п, и, сі, +6, и исі (3.1.3 Типы одна-ячейка, 3.1.4 Типы пара¬ 
ячеек) ; 

- зоны области данных только-для-чтения (3.3.3 Область данных); 

- размер буфера в 6.1.2450 МОРО (3.3.3.6 Другие временные области); 

- размер одной ячейки в адресуемых элементах (3.1.3 Типы одна-ячейка); 

- размер одного символа в адресуемых элементах (3.1.2 Символьные типы); 

- размер входного буфера клавиатуры терминала (3.3.3.5 Входные буферы); 

- размер буфера строки вывода отображаемого числа (3.3.3.6 Другие временные 
области); 

- размер рабочей области, чей адрес возвращен 6.2.2000 РАО (3.3.3.6 Другие 



временные области); 

- системные регистро-чувствительные характеристики (3.4.2 Поиск имен 
определений) ; 

- системное приглашение (3.4 Интерпретатор текста РогШ, 6.1.2050 ЦІІІТ); 

- тип округления деления (3.2.2.1 Целочисленное деление, 6.1.0100 */, 
6.1.0110 ѴМОР, 6.1.0230 /, 6.1.0240 /МОР, 6.1.1890 МОР); 
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- значения 6.1.2250 5ТАТЕ, если Ігие; 

- значения, возвращаемые после арифметического переполнения (3.2.2.2 Другие 
целочисленные операции); 

- может ли текущее определение быть найдено после 6.1.1250 00ЕЗ> (6.1.0450 :). 

4.1.2 _ 

Неоднозначные условия 

Система должна документировать системное действие, предпринимаемое на каждое 
общее или специфическое неоднозначное условие, идентифицированное в этом 
Стандарте. См. 3.4.4 Возможное действие на неопределенную ситуацию. 

Следующие общие неоднозначные условия могут происходить из-за комбинации 
факторов: 

- имя не определено ни допустимым именем определения, ни допустимым числом в 
течение интерпретации текста (3.4 Интерпретатор текста РогІИ); 

- имя определения превысило максимальную допустимую длину (3.3.1.2 Имена 
определений); 

- адресование области, не перечисленной в 3.3.3 Области данных; 

- тип параметра, несовместимый с указанным входным параметром, например, 
передача флага слову ожидающему п (3.1 Типы данных); 

- попытка получить идентификатор исполнения (например, с помощью 6.1.0070 ', 
6.1.1550 РІШ, и т.д.) определения с неопределенной семантикой интерпретации; 

- деление на ноль (6.1.0100 */, 6.1.0110 */М00, 6.1.0230 /, 6.1.0240 /то, 
6.1.1561 РМ/МОО, 6.1.1890 МОР, 6.1.2214 5М/РЕМ, 6.1.2370 ІІМ/МОР, 

8.6.1.1820 МѴ) ; 

- недостаточный размер стека данных или размер стека возвратов (переполнение 
стека); 

- недостаточно места для параметров 1оор-соп1;го1; 

- недостаточно места в словаре; 

- интерпретация слова с неопределенной семантикой интерпретации; 

- изменение содержания входного буфера или строкового литерала (3.3.3.4 Области 
текстовых констант, 3.3.3.5 Входные буферы); 

- переполнение строки вывода отображаемого числа; 

- переполнение анализируемой строки; 

- производимый результат вне диапазона, например умножение (с использованием *) 
приводит к значению слишком большому, чтобы быть представленным целым числом 
одна-ячейка (6.1.0090 *, 6.1.0100 V, 6.1.0110 */М00, 6.1.0570 >І\ІІІМВЕК, 
6.1.1561 РМ/МОО, 6.1.2214 5М/КЕМ, 6.1.2370 11М/М00, 6.2.0970 СОМѴЕКТ, 
8.6.1.1820 МѴ) ; 

- чтение из пустого стека данных или стека возвратов (выход за нижнюю границу 
стека); 

- неожиданный конец входного буфера, приводящий к попытке использовать строку 
нулевой длины как имя; 

Следующие специфические неоднозначные условия отмечены в словарных входах 
важных слов: 

- >ІМ больше чем размер входного буфера (3.4.1 Синтаксический анализ); 

- 6.1.2120 РЕСІІК5Е появляется после 6.1.1250 00Е5>; 

- параметр источника ввода, отличный от текущего входного источника для 
6.2.2148 РЕ5Т0РЕ- ІИРІІТ ; 

- область данных, содержащая определения освобождена (3.3.3.2 Непрерывные 



области); 

- чтение-запись области данных с неправильным выравниванием (3.3.3.1 
Выравнивание адреса); 

- указатель области данных, не должным образом выровненный (6.1.Ѳ15Ѳ ,, 

6.1.0860 С, ); 

- меньше чем и+2 элементов в стеке (6.2.2030 РІСК, 6.2.2150 РОІ_І_); 

- параметры Іоор-сопбгоі не доступны (6.1.0140 +1_00Р, 6.1.1680 I, 6.1.1730 1, 
6.1.1760 І.ЕАѴЕ, 6.1.1800 ЮОР, 6.1.2380 1ШЮ0Р); 
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- самое последнее определение не имеет имени (6.1.1710 ІММЕОІАТЕ); 

- имя, не определенное 6.2.2405 ѴАШЕ, для использования с 6.2.2295 ТО; 

- имя, не найдено (6.1.0070 ', 6.1.2033 Р03ТР0МЕ, 6.1.2510 ['], 

6.2.2530 [СОМРІІ.Е]); 

- параметры не одного типа (6.1.1240 00, 6.2.0620 ?00, 6.2.2440 МИНИМ); 

- 6.1.2033 Р03ТР0МЕ, или 6.2.2530 [СОМРІІ_Е] применено к 6.2.2295 ТО; 

- строка длиннее, чем строка со счетчиком возвращенная 6.1.2450 МОРО; 

- и больше или равно числу битов в ячейке (6.1.1805 І_5НІРТ, 6.1.2162 РЗНІРТ); 

- слово, не определенное с помощью 6.1.1000 СРЕАТЕ (6.1.0550 >ВООУ, 

6.1.1250 00ЕЗ> ); 

- слова, ненадлежащим образом используемые вне 6.1.0490 <# и 6.1.0040 #> 
(6.1.0030 #, 6.1.0050 #5, 6.1.1670 НОЮ, 6.1.2210 5І6М). 

4.1.3 _ 

Другая системная документация 

Система должна предоставить следующую информацию: 

- список нестандартных слов, использующих 6.2.2000 РАО (3.3.3.6 Другие 
временные области); 

- доступные терминальные средства оператора; 

- доступная область данных программы, в адресуемых элементах; 

- доступный размер стека возвратов, в ячейках; 

- доступный размер стека, в ячейках; 

- требуемое системное пространство словаря, в адресуемых элементах. 

4.2 _ 

Программная документация 

4.2.1 _ 

Зависимости окружения 

Программа должна документировать следующие зависимости окружения, где они 
применяются, и должна документировать другие известные зависимости окружения: 

- рассмотрение буфера строки вывода отображаемого числа фиксированной областью 
с неизменными параметрами доступа (3.3.3.6 Другие временные области); 

- зависимости присутствия или отсутствия неграфических символов в полученной 
строке (6.1.0695 АССЕРТ, 6.2.1390 ЕХРЕСТ); 

- доверие к особенностям направления округления (3.2.2.1 Целочисленное 
деление); 

- требования к особенностям представления чисел и арифметики (3.2.1.1 
Внутреннее представление числа); 

- требование к нестандартным словам или методам (3. Условия применения); 

- требование к способности посылать или получать управляющие символы (3.1.2.2 
Управляющие символы, 6.1.1750 КЕУ); 

- использование управляющих символов, для выполнения специфических функций 
(6.1.1320 ЕМІТ, 6.1.2310 ТУРЕ); 

- использование флагов как арифметических операндов (3.1.3.1 Флаги); 

- использование строчных букв для стандартных имен определений или зависимость 
от чувствительности к регистру системы (3.3.1.2 Имена определений); 

- использование графического символа со значением Иех 24 (3.1.2.1 Графические 



символы) . 

4.2.2 _ 

Другая программная документация 

Программа должна также документировать: 
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- минимальные требования терминальных средств оператора; 

- существует ли Стандартная система после загрузки программы. 
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5. _ 

Соглашение и наименование 

5.1 _ 

А№ РогИп системы 

5.1.1 _ 

Системное соглашение 

Система, которая соблюдает все системные требования разделов 3. Условия 
применения и 4.1 Системная документация и их подразделов - Стандартная система. 
Иначе Стандартная система, которая предоставляет только часть основных слов - 
подмножество Стандартной системы. Иначе Стандартная система (подмножество), 
которая не в состоянии соблюдать один или большее количество минимальных 
значений или диапазонов, указанных в 3. Условия применения и их подразделы - 
имеет ограничения окружающей среды. 

5.1.2 _ 

Системное наименование 

Стандартная система (подмножество) должна быть именована "А№ Рогіііі система 
(подмножество)". Это наименование не должно применяться к Стандартным системам 
или Стандартным системам подмножествам, которые имеют ограничения окружающей 
среды. 

Фраза "с ограничениями окружающей среды" должна быть добавлена в конец 
наименования Стандартной системы (подмножества), которая имеет ограничения 
окружающей среды. 

Фраза "Предоставляет имена из расширений основного набора слов" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет части 
расширений основного набора слов. 

Фраза "Предоставляет расширения основного набора слов" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет все расширения 
основного набора слов. 

5.2 _ 

А№ РогІП программы 

5.2.1 _ 

Программное соглашение 

Программа, которая соблюдает все программные требования разделов 3. Условия 
применения и 4.2 Программная документация и их подразделы - Стандартная 
программа. 


5.2.2 



Программное наименование 


Стандартная программа должна быть именована "АІ\І5 Рогбб программа". Это 
наименование не должно применяться к Стандартным программам, которые требуют, 
чтобы система предоставляла стандартные слова вне Основного набора слов или она 
имеет зависимость от окружения. 

Фраза "с Зависимостями от окружения" должна быть добавлена наименования 
Стандартной программы, которая имеет зависимость от окружения. 

Фраза "Требуются имена из расширений основного набора слов" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширений основного набора. 

Фраза "Требуются расширения основного набора слов" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
все расширения основного набора. 
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6 . _ 

Словарь 

6.1 _ 

Основные слова 


6.1.ѲѲ1Ѳ ! "збоге " СОРЕ 

( х а-асісіг -- ) 

Сохраняет х в а-асісіг . 

См.: 3.3.3.1 Выравнивание адреса. 

6.1.0030 # "питЬег-зідп" СОРЕ 

( исіі -- исІ2 ) 

Делит исіі числом в ВАЗЕ, дает частное исІ2 и остаток п. (п - младший 
разряд исіі.) Преобразовывает п к внешней форме и добавляет 
результирующий символ к началу выходной строки отображаемого числа. 
Неопределенная ситуация существует если # выполняется вне <# #> 
ограничивающих преобразование числа. 

См.: 6.1.0040 #>, 6.1.0050 #5, 6.1.0490 <#. 

6.1.0040 #> "питЬег-зідп-дгеаІіег" СОРЕ 

( хсі -- с-асісіг и ) 

Удаляет хсі . Делает выходную строку отображаемого числа доступной 
как символьную строку. С-асісіг и и определяют результирующую 
символьную строку. Программа может заменять символы в пределах 
строки. 

См.: 6.1.0030 #, 6.1.0050 #5, 6.1.0490 <#. 

6.1.0050 #5 "питЬег-зідп-з" СОРЕ 

( исіі -- исІ2 ) 

Преобразует одну цифру исіі согласно правилу для #. Продолжает 
преобразование до нулевого частного. исІ2 нулевое. Неопределенная 
ситуация существует, если #5 выполняется вне <# #> ограничивающих 
преобразование числа. 

См.: 6.1.0030 #, 6.1.0040 #>, 6.1.0490 <#. 

6.1.0070 ' "Иск" СОРЕ 

( "<зрасез>пате" -- хі ) 

Пропускает ведущие разделители пробелы. Выделяет пате ограниченное 
пробелом. Ищет пате, и возвращает хі, идентификатор исполнения для 



пате. Неопределенная ситуация существует, если пате не найдено. 

При интерпретации, 1 ху 2 ЕХЕСІІТЕ, эквивалентно ху 2 . 

См.: 3.4 Интерпретатор текста РогІИ, 3.4.1 Синтаксический анализ, 
А.6.1.2ѲЗЗ РОЗТРСШЕ, А.6.1.2510 ['], 0.6.7 Іттесііаііе - ности . 

6.1.0080 ( "рагеп" СОРЕ 

Компиляция: Исполняет семантику выполнения, данную ниже. 
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Выполнение: ( "ссс<рагеп>" -- ) 

Выделяет ссс, ограниченное ) (правая круглая скобка). ( - слово 
немедленного исполнения. 

Число символов в ссс может быть нулевое для числа символов в 
области анализа. 

См.: 3.4.1 Синтаксический анализ, 11.6.1.0080 (. 

* "збаг" СОРЕ 

( п11 иі п2|и2 - - пЗ|иЗ ) 

Умножает п1|и1 на п2|и2, возвращает пЗ|иЗ. 

*/ "зіаг-зіазб" СОРЕ 

( п1 п2 пЗ -- п4 ) 

Умножает пі на п2, с промежуточным результатом двойная-ячейка б. 
Делит б на пЗ, выдает частное одна-ячейка п4. Неопределенная 
ситуация существует, если пЗ нулевое или если частное п4 находится 
вне диапазона числа со знаком. Если б и пЗ отличаются по знаку, 
возвращенный результат, определенный реализацией будет такой же 
самый, как и возвращаемый фразой >Р М* Р> РМ/М00 5\л/АР 0Р0Р или 
фразой >Р М* Р> 5М/РЕМ 5ЫАР ОРОР. 


См.: 3.2.2.1 Целочисленное деление. 


6.1.0110 

*/моо 

"збаг-зіазіі-тосі" 

СОРЕ 


( пі п2 пЗ -- п4 п5 ) 




Умножает пі на п2, с промежуточным результатом двойная-ячейка б. 
Делит б на пЗ, выдает остаток одна-ячейка п4 и частное одна-ячейка 
п5. Неопределенная ситуация существует, если пЗ нулевое или если 
частное п5 находится вне диапазона числа одна-ячейка со знаком. 

Если сі и пЗ отличаются по знаку, возвращенный результат, 
определенный реализацией будет тот же самый, как и возвращаемый 
фразой >Р М* Р> РМ/М00 или фразой >Р М* Р> 5М/РЕМ. 

См.: 3.2.2.1 Целочисленное деление. 

6.1.0120 + "ріиз" СОРЕ 

( пі | иі п2|и2 - - пЗ|иЗ ) 

Прибавляет п2|и2 к п1[и1, возвращая сумму пЗ|иЗ. 

См.: 3.3.3.1 Выравнивание адреса. 

6.1.0130 +! "ріиз-зіоге" СОРЕ 

( п | и а-асісіг -- ) 

Прибавляет п | и к числу одна-ячейка в а-асісіг. 

См.: 3.3.3.1 Выравнивание адреса. 

6.1.0140 +Ц00Р "ріиз-іоор" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 


6.1.0090 


6.1.0100 
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Компиляция: ( С: сіо-зуз -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. Разрешает назначения для всех неразрешенных ссылок 
І_ЕАѴЕ между местоположением, данным сіо-зуз и следующим 
местоположением для перехода к выполнению слова после +1_00Р. 

Время-выполнения: ( п - - ) ( К: Іоор-зузі -- | 1оор-5уз2 ) 

Неопределенная ситуация существует, если параметры управления 
циклом недоступны. Прибавляет п к индексу цикла. Если индекс цикла 
не пересекал границу между пределом цикла минус один и пределом 
цикла, продолжает выполнение с начала цикла. Иначе, удаляет текущие 
параметры управления цикла и продолжает выполнение сразу после 
цикла. 


См.: 6.1.1240 00, 6.1.1680 I, 6.1.1760 І_ЕАѴЕ . 

6.1.0150 , "сотша" СОРЕ 

( х -- ) 

Резервирует одну ячейку области данных, и сохраняет х в ячейке. 

Если указатель области данных выровнен перед выполнением то он 

останется выровненным после окончания выполнения 

Неопределенная ситуация существует если указатель области данных не 
выровнен перед выполнением 

См.: 3.3.3 Область данных, 3.3.3.1 Выравнивание адреса. 

6.1.0160 - "тіпиз" СОРЕ 

( п11 иі п2|и2 - - пЗ|иЗ ) 

Вычитает п2|и2 из п1|и1, и возвращает разницу пЗ|иЗ. 

См.: 3.3.3.1 Выравнивание адреса. 

6.1.0180 . "сіоі" СОРЕ 

( п -- ) 

Отображает п в формате свободного поля. 

См.: 3.2.1.2 Преобразование цифр, 3.2.1.3 Изображение чисел в 
свободном поле. 

6.1.0190 ." "сіоі-ціюііе" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "ссс<цію1:е>" -- ) 

Выделяет ссс, ограниченную " (двойная кавычка). Добавляет семантику 
времени-выполнения данную ниже к текущему определению. 

Время-выполнения: ( -- ) 

Отображает ссс. 

См.: 3.4.1 Синтаксический анализ, 6.2.0200 .(. 

6.1.0230 / "зіазіі" СОРЕ 
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( пі п2 -- пЗ ) 

Делит пі на п2, возвращает частное одна-ячейка пЗ. Неопределенная 
ситуация существует, если п2 нулевое. Если пі и п2 отличаются по 
знаку, возвращенный результат, определенный реализацией будет тот 



же самый, как и возвращаемый фразой Ж 5>Р Р> РМ/МСЮ 5\л/АР ОРОР или 
фразой >Р 5>Р Р> 5М/РЕМ 5МАР ЭРОР. 


См 

6.1.0240 


См 

6.1.0250 

6.1.0270 

6.1.0290 

6.1.03ѲѲ 

6.1.Ѳ31Ѳ 

См 

6.1.032Ѳ 

6.1.0330 


6.1.0350 

См 

6.1.0370 


: 3.2.2.1 Целочисленное деление. 

/М00 "зіазіі-тосі" СОРЕ 

( п1 п2 -- пЗ п4 ) 

Делит п1 на п2, возвращает остаток одна-ячейка пЗ и частное одна- 
ячейка п4. Неопределенная ситуация существует, если п2 нулевое. 

Если пі и п2 отличаются по знаку, возвращенный результат, 
определенный реализацией будет тот же самый, как и возвращаемый 
фразой >Р 5Ж Р> РМ/МОР или фразой >Р 5>0 Р> 5М/РЕМ. 

: 3.2.2.1 Целочисленное деление. 


ѳ< 

"гего-іезз" 

СОРЕ 

( п -- біад ) 
біад - Ігие, если и 

только если п - меньше нуля. 


0= 

"гего-едиаіз" 

СОРЕ 

( х -- біад ) 
біад - бше, если и 

только если х - равно нулю. 


1+ 

"опе-ріиз" 

СОРЕ 

( п1|и1 -- п2|и2 ) 
Прибавляет один(1) к 

п1|и1 возвращает сумму п2|и2. 


1- 

"опе-шіпиз" 

СОРЕ 

( п1|и1 -- п2|и2 ) 
Вычитает один (1) из 

п1|и1, возвращает разницу п2|и2. 


2! 

"бмо-збоге" 

СОРЕ 

( хі х2 а-асісіг -- ) 




Сохраняет пару-ячеек хі х2 в а-асісіг, х2 в а-асісіг и хі в следующей 
последовательной ячейке. Это эквивалентно последовательности 5ЫАР 
ОѴЕР ! СЕІ_І_+ !. 

3.3.3.1 Выравнивание адреса. 


2* "біл/о-збаг" СОРЕ 

( хі -- х2 ) 

х2 - результат смещения хі на один бит к старшему двоичному 
разряду, заполнение освобожденного младшего бита нулем. 

2/ "био-зіазб" СОРЕ 

( хі -- х2 ) 

х2 - результат смещения хі на один бит к младшему двоичному 
разряду, оставляет старший бит неизменным. 
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2@ "біл/о-бебсб" СОРЕ 

( а-асісіг -- хі х2 ) 

Извлекает пару-ячеек хі х2 сохраненную в а-асісіг. х2 сохранено в а- 
асісіг и хі в следующей последовательной ячейке. Это эквивалентно 
последовательности ЭІІР СЕІ_І_+ @ 5ЫАР 

: 3.3.3.1 Выравнивание адреса, 6.1.0310 2!. 

2ЭР0Р "Ііл/о-сігор" СОРЕ 

( хі х2 -- ) 

Удаляет пару-ячеек хі х2 из стека. 



6.1.0380 2РІІР "Імо-сіііре" СОРЕ 

( хі х2 -- хі х2 хі х2 ) 

Дублирует пару-ячеек хі х2. 

6.1.0400 20ѴЕР "Імо-оѵег" СОРЕ 

( хі х2 хЗ х4 -- хі х2 хЗ х4 хі х2 ) 

Копирует пару-ячеек хі х2 на вершину стека. 

6.1.0430 25МАР "Ііл/о-змар" СОРЕ 

( хі х2 хЗ х4 -- хЗ х4 хі х2 ) 

Меняет местами две верхних пары-ячеек. 

6.1.0450 : " соіоп " СОРЕ 

( С: "<зрасез>пате" -- соіоп-зуз ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для паше, называемое "определение 
через двоеточие". Вводит состояние компиляции и начинает текущее 
определение, создавая соіоп-зуз. Добавляет семантику инициирования, 
данную ниже к текущему определению. 

Семантика выполнения пате будет определяться скомпилированными в 
тело определения словами. Текущее определение не должно быть 
находимым в словаре, пока оно не закончено (или до выполнения 00ЕЗ> 
в некоторых системах). 

Инициирование: ( і*х -- і*х ) ( Р: -- пезі-зуз ) 

Сохраняет зависящую-от-реализации информацию пезі-зуз о вызове 
определения. Состояние стека і*х, представляет параметры для пате. 

пате Выполнение: ( і*х -- д*х ) 

Выполняет пате определения. Состояние стека і*х, и і*х представляет 
параметры и результаты из пате, соответственно. 

См.: 3.4 Интерпретатор текста Рогій, 3.4.1 Синтаксический анализ, 

3.4.5 Компиляция, 6.1.1250 Р0Е5>, 6.1.2500 [, 6.1.2540 ], 
15.6.2.0470 ;СОРЕ. 

6.1.0460 ; "зетісоіоп" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 
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Компиляция: ( С: соіоп-зуз -- ) 

Добавляет семантику времени-выполнения ниже к текущему определению. 
Заканчивает текущее определение, позволяя ему быть найденным в 
словаре, и вводит состояние интерпретации, потребляя соіоп-зуз. 

Если указатель области данных не выровненный, резервирует 
достаточно области данных для его выравнивания. 

Время-выполнения: ( -- ) ( Р: пезі-зуз -- ) 

Возвращение к вызывающему определению, определенному пезі-зуз. 

См.: 3.4 Интерпретатор текста РогІІі, 3.4.5 Компиляция. 

6.1.0480 < "Іезз-ІІіап" СОРЕ 

( п1 п2 -- Над ) 

Над - Ігие, если и только если пі - меньше чем п2. 

См.: 6.1.2340 ІК. 

6.1.0490 <# "Іезз-питЬег-зідп" СОРЕ 

( -- ) 

Инициализирует процесс выходного преобразования отображаемого 



числа. 


См.: 6.1.ѲѲЗѲ #, 6.1.0040 #>, 6.1.0Ѳ5Ѳ #5. 

6.1.0530 = "едыаіз" СОРЕ 

( хі х2 -- Над ) 

Над - Ігие, если и только если хі - побитно равно х2. 

6.1.0540 > "дгеаІег-ІПап" СОРЕ 

( пі п2 -- -Лад ) 

Лад - Ігие, если и только если пі - больше чем п2. 

См. : 6.2.2350 ІІ>. 

6.1.0550 >В00У "Іо-Ьосіу" СОРЕ 

( хі -- а-асісіг ) 

а-асісіг - адрес области данных соответствующей хі. Неопределенная 
ситуация существует, если хі не для слова определенного через 
СРЕАТЕ. 

См.: 3.3.3 Область данных. 

6.1.0560 >ІМ "1о-іп" СОРЕ 

( -- а-асісіг ) 

а-асісіг - адрес ячейки, содержащей смещение в символах от начала 
входного буфера до начала области анализа. 

6.1.0570 >І\ІІІМВЕР "Іо-піітЬег" СОРЕ 

( исіі с-асісігі иі -- исІ2 с-асІсІг2 и2 ) 

исІ2 - без знаковый результат преобразования символов из строки 
указанной с-асісігі иі в цифры, используя число в ВАЗЕ, и добавления 
каждого в исіі после умножения исіі на число из ВАЗЕ. 
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Преобразование продолжается слева направо до встречи не 
преобразуемого символа, включая "+" или или пока строка 

полностью не будет преобразована, с - асісі г2 - местоположение первого 
не преобразованного символа или первого символа после конца строки, 
если строка была полностью преобразована. и2 - число не 
преобразованных символов в строке. Неопределенная ситуация 
существует если исІ2 переполняется в процессе преобразования. 

См.: 3.2.1.2 Преобразование цифр. 

6.1.0580 Ж "1о-г" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: (х--) (Р: --х) 

Перемещает х на стек возвратов. 

См.: 3.2.3.3 Стек возвратов, 6.1.2060 Н>, 6.1.2070 Н@, 6.2.0340 2>Н, 
6.2.0410 2Р>, 6.2.0415 2Н@. 

6.1.0630 701ІР "диезііоп-сіире" СОРЕ 

( х -- 0 | х х ) 

Дублирует х, если оно ненулевое. 

6.1.0650 @ "ГеІсИ" СОРЕ 

( а-асісіг -- х ) 

х - значение, сохраненное в а-асісіг. 

См.: 3.3.3.1 Выравнивание адреса. 



СОРЕ 


6.1.0670 АБОРТ 

( і * х -- ) ( Р: ^ * х -- ) 

Освобождает стек данных и выполняет функцию фШТ, которая включает 
освобождение стека возвратов, без отображения сообщения. 

См.: 9.6.2.0670 АБОРТ. 

6.1.0680 АБОРТ" "аЬогІ-циоІе" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "ссс<цио1:е>" -- ) 

Выделяет ссс, ограниченную " (двойная кавычка). Добавляет семантику 
времени-выполнения данную ниже к текущему определению. 

Время-выполнения: ( і*х хі -- | і*х ) ( Р: }*х -- | ^*х ) 

Удаляет хі из стека. Если какой либо бит хі - не нулевой, 
отображает ссс и выполняет определенную реализацией 
последовательность сброса, которая включает функцию АБОРТ. 

См.: 3.4.1 Синтаксический анализ, 9.6.2.0680 АБОРТ". 

АВ5 "аЬз" СОРЕ 

( п -- и ) 

и - абсолютное значение п. 
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АССЕРТ СОРЕ 

( с-асісіг +п1 -- +п2 ) 

Получает строку с максимумом +п1 символов. Неопределенная ситуация 
существует, если +п1 нулевое или больше чем 32767. Отображает 
полученные графические символы. Программа, которая зависит от 
присутствия или отсутствия неграфических символов в строке имеет 
зависимость от окружающей среды. Функции редактирования, если 
таковые вообще имеются, которые система исполняет при создании 
строки - определенное реализацией. 

Ввод заканчивается, когда получен определенный реализацией признак 
конца строки. Когда ввод заканчивается, ничего не добавляется в 
конец строки, и отображение обеспечивается определенным реализацией 
способом. 

+п2 - длина строки, сохраненной в с-асісіг. 

АІ_І6І\І СОКЕ 

( -- ) 

Если указатель области данных не выровнен, резервирует достаточно 
пространства, для его выравнивания. 

См.: 3.3.3 Область данных, 3.3.3.1 Выравнивание адреса. 

6.1.0706 АІЛ6ІЧЕ0 СОКЕ 

( асісіг -- а-асісіг ) 

а-асісіг - первый выровненный адрес большее чем или равный асісіг. 

См.: 3.3.3.1 Выравнивание адреса. 

6.1.0710 АШОТ СОКЕ 

( п -- ) 

Если п больше нуля, резервирует п адресуемых элементов области 
данных. Если п меньше нуля, освобождает | п | адресуемых элементов 
области данных. Если п нуль, оставляет указатель области данных 


6.1.0690 


6.1.0695 


6.1.0705 



неизменным. 


Если указатель области данных выровнен, и п - кратно размеру ячейки 
перед выполнением АІ_І_ОТ, он останется выровненным, и после 
завершения выполнения А1_І_0Т . 

Если указатель области данных выровнен на символ, и п - кратно 
размеру символа перед выполнением АШЭТ, он останется выровненным 
на символ, и после завершения выполнения АШЭТ. 

См.: 3.3.3 Область данных. 

6.1.0720 АШ СОРЕ 

( хі х2 -- хЗ ) 

хЗ поразрядное логическое "и" хі и х2. 
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6.1.0750 ВАЗЕ СОРЕ 

( -- а-асісіг ) 

а-асісіг - адрес ячейки, содержащей текущее основание системы 
счисления для преобразования чисел {{2...36}}. 

6.1.0760 ВЕС^ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: (С: -- сіезі ) 

Помещает адрес следующей ячейки для передачи управления, сіезі; , на 
стек потока-управления. Добавляет семантику времени-выполнения, 
данную ниже к текущему определению. 

Время-выполнения: ( -- ) 

Продолжает выполнение. 

См.: 3.2.3.2 Стек потока-управления, 6.1.2140 РЕРЕАТ, 6.1.2390 ІІІ\ІТІІ_, 
6.1.2430 ѴѴНІІ-Е. 


6.1.0770 

ВЦ 

"Ь-1" 

СОРЕ 


( -- сПаг ) 

сПаг - символьное значение для 

пробела. 


6.1.0850 

С! 

"с-зіоге" 

СОРЕ 


( сПаг с-асісіг -- ) 

Сохраняет сПаг в с-асісіг. Когда 

размер символа меньше 

чем размер 


ячейки, переданы только младшие 

биты, соответствующие 

размеру 


символа. 



См 

. : 3.3.3.1 Выравнивание адреса. 



6.1.0860 

с, 

"с-сошта" 

СОРЕ 


( сііаг -- ) 




Резервирует пространство для одного символа в области данных и 
запоминает сПаг в нем. Если указатель области данных - выровнен на 
символ перед выполнением С,, он останется выровненным на символ и 
после окончания выполнения С,. Неопределенная ситуация существует, 
если указатель области данных - не выровненный на символ до 
выполнения С, . 

См.: 3.3.3 Область данных, 3.3.3.1 Выравнивание адреса. 

6.1.0870 С@ "с-ГеИсН" СОРЕ 

( с-асісіг -- сПаг ) 

Выбирает символ, сохраненный в с-асісіг. Когда размер ячейки больше 



чем размер символа, все неиспользованные старшие биты - нули. 


См.: 3.3.3.1 Выравнивание адреса. 

6.1.088Ѳ СЕЫ.+ "сеіі-ріиз" СОРЕ 

( а-асісігі -- а-асІсІг2 ) 
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Добавляет размер в адресуемых элементах ячеек к а-асісігі, возвращает 
а-абсІг2 . 

См.: 3.3.3.1 Выравнивание адреса. 

6.1.0890 СЕЫ.5 СОРЕ 

( пі -- п2 ) 

п2 - размер в адресуемых элементах пі ячеек. 

6.1.0895 СНАР "сбаг" СОРЕ 

( "<зрасез>пате" -- сбаг ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Помещает значение его первого символа на стек. 

См.: 3.4.1 Синтаксический анализ, 6.1.2520 [СНАР]. 

6.1.0897 СНАР+ "сбаг-ріиз" СОРЕ 

( с-асісігі -- с-асІсІг2 ) 

Добавляет размер в адресуемых элементах символа к с-асісігі, 
возвращает с-абсІг2. 

См.: 3.3.3.1 Выравнивание адреса. 

6.1.0898 СНАР5 "сбагз" СОРЕ 

( пі -- п2 ) 

п2 - размер в адресуемых элементах пі символов. 

6.1.0950 СОИЗТАІМТ СОРЕ 

( х "<зрасез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения, 
определенной ниже. 

пате объявляется как "сопзіапб" . 

пате Выполнение: ( -- х ) 

Размещает х на стеке. 

См.: 3.4.1 Синтаксический анализ. 

6.1.0980 СОІІМТ СОРЕ 

( с-асісігі -- с-абсІг2 и ) 

Возвращает спецификацию символьной строки для строки со счетчиком 
сохраненной в с-асісігі. с-асІсІг2 - адрес первого символа после с- 
асісігі. и - содержимое символа в с-асісігі, который является длиной в 
символах строки в с-абсІг2. 

6.1.0990 СР "с-г" СОРЕ 

( -- ) 

Заставляет последующий вывод появляться в начале следующей строки. 

6.1.1000 СРЕАТЕ СОРЕ 

( "<зрасез>пате" -- ) 
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Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения, 
определенной ниже. Если указатель области данных не выровнен, 
резервирует достаточно области данных для его выравнивания. Новый 
указатель области данных определяет поле данных пате. СРЕАТЕ не 
распределяет область данных в поле данных пате. 

пате Выполнение: ( -- а-асісіг ) 

а-асісіг - адрес поля данных пате. Семантика выполнения пате может 
быть расширена использованием 00Е5>. 

См.: 3.3.3 Область данных, 6.1.1250 00ЕЗ>. 


6.1.1170 

ОЕСІМАЦ 

СОРЕ 


( -- ) 

Устанавливает основание системы счисления преобразования чисел 
десять (десятичные числа). 

на 

6.1.1200 

РЕРТН 

СОРЕ 


( -- +п ) 

+п - число значений данных одна-ячейка, содержащихся на стеке 
данных перед тем, как +п было помещено на стек. 


6.1.1240 

ОО 

СОРЕ 


Интерпретация: Семантика интерпретации для этого слова не определена. 


Компиляция: (С: -- сіо-зуз ) 

Помещает сіо-зуз на стек потока управления. Добавляет семантику 
времени-выполнения данную ниже к текущему определению. Семантика не 
завершена, пока сіо-зуз не разрешена потребителем типа 1_00Р. 

Время-выполнения: ( п1|и1 п2|и2 -- ) ( Р: -- Іоор-зуз ) 

Устанавливает параметры управления цикла с индексом п2|и2, и 
границей п1|и1. Неопределенная ситуация существует, если оба п1|и1 
и п2|и2- не одного типа. Что-либо уже имеющееся на стеке возвратов 
становится недоступным до удаления параметров управления циклом. 

См.: 3.2.3.2 Стек потока управления, 6.1.0140 +1_00Р, 6.1.1800 1_00Р. 

6.1.1250 Р0Е5> "сіоез" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: соіоп-зузі -- со1оп-зуз2 ) 

Добавляет семантику времени-выполнения ниже к текущему определению. 
В любом случае текущее определение представленное находимым в 
словаре при компиляции 00ЕЗ> - определенное реализацией. Потребляет 
соіоп-зузі и производит со1оп-зуз2. Добавляет семантику 
инициирования, данную ниже к текущему определению. 

Время-выполнения: ( -- ) ( Р: пезі-зузі -- ) 

Заменяет семантику выполнения самого последнего определения, 
упоминаемого как пате, семантикой выполнения имени данной ниже. 
Возвращает управление на вызывающее определение, определенное пезі;- 
зузі. Неопределенная ситуация существует если пате не было 
определено СРЕАТЕ, или определенным пользователем словом которое 
вызывает СРЕАТЕ. 
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Инициирование: ( і*х -- і*х а-асісіг ) ( Р: -- пезі-зузг ) 



Сохраняет зависящую-от-реализации информацию пезі-зузг о вызывающем 
определении. Размещает адрес поля данных пате на стеке. Состояние 
стека і*х представляет параметры пате. 

пате Выполнение: ( і*х -- д*х ) 

Выполняет часть определения, которая начинается с семантики 
инициирования добавленной изменившим пате 00Е5>. Состояния стека 
і*х и і*х представляют параметры, и результаты пате, 
соответственно. 


См.: 6.1.1000 СРЕАТЕ. 


6.1.1260 

ОРОР 
( X -- ) 

Удаляет х из стека. 


СОРЕ 

6.1.1290 

РІІР 

( X -- X х ) 

Дублирует х. 

"сіире" 

СОРЕ 

6.1.1310 

ЕІ_5Е 


СОРЕ 


Интерпретация: Семантика интерпретации для этого слова не определена. 


Компиляция: ( С: огіді -- огід2 ) 

Помещает адрес ячейки новой неразрешенной ссылки вперед огід2 на 
стек потока управления. Добавляет семантику времени-выполнения 
данную ниже к текущему определению. Семантика будет не завершена, 
пока огід2 не разрешена (например, ТНЕІМ). Разрешает ссылку вперед 
огіді использованием адреса ячейки после добавленной семантики 
времени-выполнения. 

Время-выполнения: ( -- ) 

Продолжает выполнение с адреса ячейки данного ссылкой огід2. 

См.: 6.1.1700 ІР, 6.1.2270 ТНЕМ. 

6.1.1320 ЕМІТ СОРЕ 

( х -- ) 

Если х - графический символ в наборе символов определенном 
реализацией - показать х. Эффект ЕМІТ для всех других значений х - 
определенное реализацией. 

Когда просматривается символ, чьи символом-определенные биты имеют 
значение между Пех 20 и 7Е включительно, отображается 
соответствующий стандартный символ, определенный 3.1.2.1 
Графические символы. Поскольку различные устройства вывода могут 
реагировать по-разному на управляющие символы, программы, 
использующие управляющие символы для выполнения специфических 
функций, имеют зависимость от окружения. Каждый ЕМІТ, имеет дело 
только с одним символом. 

См.: 6.1.2310 ТУРЕ. 
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6.1.1345 ЕІМѴІРОММЕІМТ? "епѵігоптепі: -циегу" СОРЕ 

( с-асісіг и -- Таізе | і*х ігие ) 

с-асісіг - адрес символьной строки, и и - ее размер, и может иметь 
значение в диапазоне от нуля до максимума определенного 
реализацией, но не должен быть меньше чем 31. Символьная строка 
должна содержать ключевое слово из 3.2.6 Запросы к окружению или 
дополнительных наборов слов, которое будут проверено на 
соответствие атрибутам существующей среды. Если система 



рассматривает атрибут как неизвестный, возвращается флаг - 'Гаізе; 
иначе, флаг - Іше, и возвращенное і*х имеет тип, указанный в 
таблице для запрашиваемого атрибута. 

6.1.1360 ЕѴАШАТЕ СОРЕ 

( і*х с-асісіг и -- }*х ) 

Сохраняет текущую спецификацию входного источника. Записывает минус 
- один (-1) в 501ІРСЕ-Ю, если он присутствует. Делает строку, 
описанную с-асісіг и и входным источником и входным буфером, 
устанавливает >ІІМ в нуль, и интерпретирует. Когда область анализа 
пуста, восстанавливает предыдущую спецификацию входного источника. 
Изменения состояния стека определяются интерпретируемыми словами. 

6.1.1370 ЕХЕСІІТЕ СОРЕ 

( і * х хі -- ^ * х ) 

Удаляет хі из стека, и выполняет идентифицированную им семантику. 
Изменения состояния стека определяются выполненным словом. 

См.: 6.1.0070 1 , 6.1.2510 [ 1 ]. 

6.1.1380 ЕХІТ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: ( -- ) ( Р: пезі-зуз -- ) 

Возвращает управление на вызывающее определение, определенное пезі- 
зуз. Перед выполнением ЕХІТ в пределах сіо-іоор, программа должна 
удалить параметры управления циклом, выполняя ІН\ІІ_00Р. 

См.: 3.2.3.3 Стек возвратов, 6.1.2380 ІІІ\ІІ_00Р. 

РІШ СОРЕ 

( с-асісіг и сПаг -- ) 

Если и больше чем нуль, сохраняет сПаг в каждом из и 
последовательных символов в памяти, начинающейся с с-асісіг. 

РІІ\Ю СОРЕ 

( с-асісіг -- с-асісіг 0 | хі 1 | хі -1 ) 

Находит определение, по имени строки со счетчиком в с-асісіг. Если 
определение не найдено, возвращает с-асісіг и нуль. Если определение 
найдено, возвращает его идентификатор исполнения хі . Если 
определение немедленного исполнения, возвращает также один (1), 
иначе минус - один (-1). Для данной строки значения возвращенные 
РІІ\Ю, во время компиляции могут отличаться от возвращенных при не 
компиляции. 


6.1.1540 


6.1.1550 
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См.: 3.4.2 Поиск имен определений, А.6.1.0070 ', А.6.1.2510 ['], 
А. 6.1.2033 Р05ТР0ІМЕ, 0.6.7 Іттесііаііе-ности . 


6.1.1561 

РМ/МОО 

'Т-т-зІазИ-тосГ 

СОРЕ 


( сіі пі -- п2 пЗ ) 




Делит сіі на пі, возвращает минимальное частное пЗ и остаток п2. 
Входные и выходные аргументы стека знаковые. Неопределенная 
ситуация существует, если пі нулевое или если частное находится вне 
диапазона целого числа одна-ячейка со знаком. 

См.: 3.2.2.1 Целочисленное деление, 6.1.2214 5М/НЕМ, 6.1.2370 ІІМ/МОО. 

6.1.1650 НЕРЕ СОРЕ 

( -- асісіг ) 

асісіг - указатель области данных. 



См.: 3.3.3.2 Непрерывные области. 

6.1.1670 НОЮ СОРЕ 

( сНаг -- ) 

Добавляет сНаг к началу выходной строки отображаемого числа. 
Неопределенная ситуация существует если НОЮ выполняется вне <# #> 
ограничивающих преобразование числа. 

6.1.1680 I СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: ( -- п|и ) ( Р: Іоор-зуз -- Іоор-зуз ) 

п|и - копия текущего (самого внутреннего) индекса цикла. 
Неопределенная ситуация существует, если параметры управления 
циклом недоступны. 

6.1.1700 ІР СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: (С: -- огід ) 

Помещает адрес ячейки новой неразрешенной ссылки вперед огід на 
стек потока управления. Добавляет семантику времени-выполнения, 
данную ниже к текущему определению. Семантика не завершена, пока 
огід не разрешена, например ТНЕМ или ЕІ_5Е. 

Время-выполнения: ( х -- ) 

Если все биты х нулевые, продолжает выполнение с адреса ячейки 
определенного ссылкой огід. 

См.: 3.2.3.2 Стек потока-управления, 6.1.1310 ЕІ_5Е, 6.1.2270 ТНЕІМ. 

6.1.1710 ІММЕОІАТЕ СОРЕ 

( -- ) 

Делает самое последнее определение словом немедленного исполнения. 
Неопределенная ситуация существует, если самое последнее 
определение не имеет имени. 
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См.: 0.6.7 Іттесііаіе-ности . 

6.1.1720 ІІМѴЕРТ СОРЕ 

( хі -- х2 ) 

Инвертирует все биты хі, возвращает его логическую инверсию х2. 

См.: 6.1.1910 МЕСАТЕ, 6.1.0270 0=. 

6.1.1730 1 СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение^ -- п|и )( Р: Іоор-зузі 1оор-зуз2 -- Іоор-зузі 1оор-зуз2 ) 
п|и - копия следующего-внешнего индекса цикла. Неопределенная 
ситуация существует, если параметры управления цикла следующего- 
внешнего цикла, Іоор-зузі, недоступны. 

6.1.1750 КЕУ СОРЕ 

( -- сНаг ) 

Получает один символ сііаг, член определенного реализацией набора 
символов. События клавиатуры, которые не соответствуют таким 
символам игнорируются, пока не получен допустимый символ, и 
впоследствии будут недоступны. 


Могут быть получены все стандартные символы. Символы, полученные 



КЕУ, не отображаются. 

Любой стандартный символ, возвращенный КЕУ имеет числовое значение 
определенное в 3.1.2.1 Графические символы. Программы, которые 
требуют способности к получению управляющих символов, имеют 
зависимость от окружения. 

См.: 10.6.2.1307 ЕКЕУ, 10.6.1.1755 КЕУ?. 

6.1.1760 І.ЕАѴЕ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: ( -- ) ( Р: Іоор-зуз -- ) 

Снимает текущие параметры управления циклом. Неопределенная 
ситуация существует, если они недоступны. Продолжает выполнение 
непосредственно вне самого внутреннего синтаксически окруженного РО 
. . . 1_00Р или 00 . . . +ЮОР. 

См.: 3.2.3.3 Стек возвратов, 6.1.0140 +1_00Р, 6.1.1800 1_00Р. 

6.1.1780 І_ІТЕРАІ_ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( х -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. 
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Время-выполнения: ( -- х ) 

Помещает х на стек. 

6.1.1800 ЦООР СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: сіо-зуз -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. Разрешает назначения для всех неразрешенных ссылок 
І_ЕАѴЕ между адресом ячейки определенным сіо-зуз и следующим за ЮОР 
адресом ячейки для передачи управления к выполнению слова после 
ЦООР. 

Время-выполнения: ( -- ) ( Р: Іоор-зузі -- | 1оор-5уз2 ) 

Неопределенная ситуация существует, если параметры управления цикла 
недоступны. Добавляет один к индексу цикла. Если после этого индекс 
цикла равен пределу цикла, снимает параметры цикла, и продолжает 
выполнение непосредственно после цикла. Иначе продолжает выполнение 
с начала цикла. 

См.: 6.1.1240 РО, 6.1.1680 I, 6.1.1760 І_ЕАѴЕ . 


6.1.1805 

Ц5НІРТ 

"1-5І1ІП" 

СОРЕ 


( хі и -- х2 ) 




Выполняет логический левый сдвиг хі на и двоичных разрядов и 
возвращает х2. Помещает нули в самые младшие биты, освобожденные 
сдвигом. Неопределенная ситуация существует, если и больше или 
равно числу битов в ячейке. 


6.1.1810 

М* 

"т-зііаг" 

СОРЕ 


( пі п2 -- сі ) 




сі - знаковое произведение пі на п2. 


6.1.1870 МАХ 


СОРЕ 



( пі п2 -- пЗ ) 
пЗ большее из пі и п2. 

6.1.1880 МІІЧ СОРЕ 

( пі п2 -- пЗ ) 
пЗ меньшее из пі и п2. 

6.1.1890 М00 СОРЕ 

( пі п2 -- пЗ ) 

Делит пі на п2, возвращает остаток пЗ одна-ячейка. Неопределенная 
ситуация существует, если п2 нулевое. Если пі и п2 отличаются по 
знаку, возвращенный результат определенный реализацией будет такой 
же самый как и возвращенный фразой >Р 5>Ц Р> РМ/МСЮ РРОР или фразой 
>Р 5>Ц Р> 5М/РЕМ ОРОР. 

См.: 3.2.2.1 Целочисленное деление. 
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6.1.1900 МОѴЕ СОРЕ 

( асісігі асІсіг2 и -- ) 

Если и больше чем нуль, копирует содержимое и последовательных 
адресуемых элементов из асісігі в и последовательных адресуемых 
элементов в асІсІг2. После завершения МОѴЕ, и последовательных 
адресуемых элементов в асІсІг2 содержат тоже, что и последовательных 
адресуемых элементов в асісігі содержали перед перемещением. 

См.: 17.6.1.0910 СМОѴЕ, 17.6.1.0920 СМ0ѴЕ> . 

6.1.1910 ІМЕ6АТЕ СОРЕ 

( пі -- п2 ) 

Отрицание пі, возвращает его арифметическую инверсию п2. 

См.: 6.1.1720 ІІМѴЕРТ, 6.1.0270 0=. 

ОР СОРЕ 

( хі х2 -- хЗ ) 

хЗ - поразрядное включающее или хі и х2. 

ОѴЕР СОРЕ 

( хі х2 -- хі х2 хі ) 

Помещает копию хі на вершине стека. 

Р05ТР0ІМЕ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "<зрасе5>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Находит пате. Добавляет семантику компиляции пате в 
текущее определение. Неопределенная ситуация существует, если пате 
не найдено. 

См.: 3.4.1 Синтаксический анализ. 

6.1.2050 фШТ СОРЕ 

( -- ) (К: і*х -- ) 

Освобождает стек возвратов, сохраняет нуль в 501ІРСЕ-Ю, если он 
присутствует, делает пользовательское устройство ввода входным 
источником, и вводит состояние интерпретации. Не отображает 
сообщение. Повторяет следующее: 

- Принимает строку из входного источника во входной буфер, обнуляет 
>ІІ\І, и интерпретирует. 


6.1.1980 


6.1.1990 


6.1.2033 



- Отображает определенную реализацией системную подсказку, если в 
состоянии интерпретации вся обработка была закончена, и нет 
неопределенной ситуации. 

См.: 3.4 Интерпретатор текста РогіИ. 

6.1.2060 Р> "г-Ггот" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 
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Выполнение: (--х) (К: х--) 

Перемещает х из стека возвратов на стек данных. 

См.: 3.2.3.3 Стек возвратов, 6.1.0580 >Р, 6.1.2070 Р@, 6.2.0340 2>Р, 
6.2.0410 2Р>, 6.2.0415 2Р@. 

6.1.2070 Р@ "г-ГебсН" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: (--х) (Р: х--х) 

Копирует х из стека возвратов на стек данных. 

См.: 3.2.3.3 Стек возвратов, 6.1.0580 >Р, 6.1.2060 Р>, 6.2.0340 2>Р, 
6.2.0410 2Р>, 6.2.0415 2Р@. 

6.1.2120 РЕСІІР5Е СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( -- ) 

Добавляет семантику выполнения текущего определения в текущее 
определение. Неопределенная ситуация существует, если РЕСІІР5Е 
появляется в определении после 00Е5>. 

См.: 6.1.1250 00Е5>, 6.1.2120 РЕСІІР5Е . 

6.1.2140 РЕРЕАТ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: огід сіезб -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению, разрешает ссылку назад сіезб . Разрешает ссылку вперед 
огід используя адрес ячейки после добавленной семантики времени- 
выполнения . 


Время-выполнения: ( -- ) 

Продолжает выполнение с адреса ячейки, данного сіезб . 


См.: 6.1.0760 ВЕСІІМ, 6.1.2430 ИННЕ. 


6.1.2160 РОТ "гобе" СОРЕ 

( хі х2 хЗ -- х2 хЗ хі ) 

Вращает три верхних элемента стека. 


6.1.2162 Р5НІРТ "г-збібб" СОРЕ 

( хі и -- х2 ) 

Выполняет правый логический сдвиг хі на и двоичных разрядов, 
возвращает х2. Помещает нули в самые старшие биты, освобожденные 
сдвигом. Неопределенная ситуация существует, если и больше или 
равно числу бит в ячейке. 


6.1.2165 5" 

Интерпретация: 


"з-циобе" СОРЕ 

Семантика интерпретации для этого слова не определена. 
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Компиляция: ( "ссс<цію1:е>" -- ) 

Выделяет ссс, ограниченную " (двойная кавычка). Добавляет семантику 
времени-выполнения данную ниже к текущему определению. 

Время-выполнения: ( -- с-асісіг и ) 

Возвращает с-асісіг и и описывающие строку, состоящую из символов 
ссс. Программа не должна изменять возвращенную строку. 

См.: 3.4.1 Синтаксический анализ, 6.2.Ѳ855 С", 11.6.1.2165 5". 

6.1.2170 5>0 "з-ІО-СІ" СОРЕ 

( п -- сі ) 

Преобразовывает число п в число сі две-ячейки с тем же самым 
числовым значением. 

6.1.2210 5І6М СОРЕ 

( п -- ) 

Если п - отрицательное, добавляет знак "минус" в начало выходной 
строки отображаемого числа. Неопределенная ситуация существует, 
если 5І6І\І выполняется вне <# #> ограничивающих преобразование 
числа. 

6.1.2214 5М/РЕМ "з-т-зіазіі- гет" СОРЕ 

( сіі п1 -- п2 пЗ ) 

Делит сіі на пі, возвращает симметричное частное пЗ и остаток п2. 
Входные и выходные параметры стека знаковые. Неопределенная 
ситуация существует, если пі нулевое или если частное находится вне 
диапазона целого числа со знаком одна-ячейка. 

См.: 3.2.2.1 Целочисленное деление, 6.1.1561 РМ/МОО, 6.1.2370 11М/М00. 

6.1.2216 501ІРСЕ СОРЕ 

( -- с-асісіг и ) 

с-асісіг - адрес, и и - число символов во входном буфере. 

6.1.2220 5РАСЕ СОРЕ 

( -- ) 

Отображает один пробел. 

6.1.2230 5РАСЕ5 СОРЕ 

( п -- ) 

Если п больше нуля, отображает п пробелов. 

6.1.2250 5ТАТЕ СОРЕ 

( -- а-асісіг ) 

а-асісіг - адрес ячейки, содержащей флаг состояния компиляции. 5ТАТЕ 
- Іше когда в состояния компиляции, иначе Таізе. Значение Іше в 
5ТАТЕ ненулевое, но - иначе определенное реализацией. Только 
следующие стандартные слова изменяют значение в 5ТАТЕ: : 

(двоеточие), ; (Точка с запятой), АВОРТ, ЦІІІТ, :І\І0І\ІАМЕ, [ (левая 
скобка), и ] (правая скобка). 
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Обратите внимание: 

Программа непосредственно не должна изменять содержание 5ТАТЕ. 

См.: 3.4 Интерпретатор текста Рогій, 6.1.0450 :, 6.1.0460 ;, 6.1.0670 
АВОРТ, 6.1.2050 фШТ, 6.1.2500 [, 6.1.2540 ], 6.2.0455 :І\І0І\ІАМЕ, 



15.6.2.2250 5ТАТЕ. 


6.1.2260 5Ѵ\/АР СОРЕ 

( хі х2 -- х2 хі ) 

Переставляет два верхних элемента стека. 

6.1.2270 ТНЕМ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: огід -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. Разрешает ссылку вперед огід, используя адрес ячейки 
добавленной семантики времени-выполнения. 

Время-выполнения: ( -- ) 

Продолжает выполнение. 

См.: 6.1.1310 ЕІ_5Е, 6.1.1700 ІР. 

6.1.2310 ТУРЕ СОРЕ 

( с-асісіг и -- ) 

Если и больше нуля, отображает символьную строку, определенную с- 
асісіг и и. 

Когда просматривается символ, чьи символом-определенные биты имеют 
значение между бех 20 и 7Е включительно, отображается 
соответствующий стандартный символ, определенный в 3.1.2.1 
Графические символы. Поскольку различные устройства вывода могут 
реагировать по-разному на управляющие символы, программы, 
использующие управляющие символы для выполнения специфических 
функций, имеют зависимость от окружения. 

См.: 6.1.1320 ЕМІТ . 


6.1.2320 

11 . 

"и-сіоі" 

СОРЕ 


( и -- ) 
Отображает и в 

формате свободного поля. 


6.1.2340 

ІІ< 

"и-іезз-ібап" 

СОРЕ 


( иі и2 -- біад 

) 



біад - ігие, если и только если иі - меньше чем и2. 


См 

. : 6.1.0480 <. 



6.1.2360 

ІІМ* 

"и-ш-зіаг" 

СОРЕ 


( иі и2 -- исі ) 




Умножает иі на и2, возвращает результат исі без знака две-ячейки. 

Все значения и арифметика без знаковые. 
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6.1.2370 

ІІМ/МОО 

"и-т-зіазб-шосі" 

СОРЕ 


( исі иі -- и2 иЗ ) 




Делит исі на иі, возвращает частное иЗ и остаток и2. Все значения и 
арифметика без знака. Неопределенная ситуация существует если иі 


нулевое или если частное находится вне диапазона целого числа одна- 
ячейка без знака. 

См.: 3.2.2.1 Целочисленное деление, 6.1.1561 РМ/МОО, 6.1.2214 5М/РЕМ. 

6.1.2380 ІІМІ.00Р СОКЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 



Выполнение: ( -- ) ( Р: Іоор-зуз -- ) 

Снимает параметры управления циклом для текущего уровня 
вложенности. ІІІ\ІІ_ООР требуется для каждого уровня вложенности 
прежде, чем может быть выполнено ЕХІТ определения. Неопределенная 
ситуация существует если параметры управления циклом недоступны. 

См.: 3.2.3.3 Стек возвратов. 

6.1.2390 ІИЧТІІ. СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: сіезі -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению, разрешая ссылку назад сіезі. 

Время-выполнения: ( х -- ) 

Если все биты х нулевые, продолжает выполнение с адреса ячейки 
определенного сіезі. 

См.: 6.1.0760 ВЕ6ІМ. 

6.1.2410 ѴАРІАВЦЕ СОРЕ 

( "<зрасез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения, 
определенной ниже. Резервирует одну ячейку области данных в 
выровненном адресе. 

пате объявляется как "ѵагіаЬІе". 

пате Выполнение: ( -- а-асісіг ) 

а-асісіг - адрес зарезервированной ячейки. Программа ответственна за 
инициализацию и содержание зарезервированной ячейки. 

См.: 3.4.1 Синтаксический анализ. 


61 


6.1.2430 ИННЕ СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: сіезі -- огід сіезі ) 

Помещает адрес ячейки новой неразрешенной ссылки вперед огід на 
стек потока управления, под существующим сіезі. Добавляет семантику 
времени-выполнения, данную ниже к текущему определению. Семантика 
не завершена до разрешения огід и сіезі (например, РЕРЕАТ). 

Время-выполнения: ( х -- ) 

Если все биты х нулевые, продолжает выполнение с адреса ячейки 
определенного ссылкой огід. 

6.1.2450 МОРО СОРЕ 

( сііаг "<сііагз>ссс<сііаг>" -- с-асісіг ) 

Пропускает ведущие разделители. Выделяет символы ссс ограниченные 
сііаг. Неопределенная ситуация существует, если длина выделенной 
строки больше чем длина определенной реализацией строки со 
счетчиком. 

с-асісіг - адрес временной области, содержащей выделенное слово как 
строку со счетчиком. Если область анализа была пуста или не 
содержала других символов кроме разделителей, результирующая строка 
имеет нулевую длину. За строкой следует не включенный в длину 
пробел. Программа может изменять символы в пределах строки. 



Примечание: Требование, о следовании пробела за строкой устаревшее и 
включено как уступка существующим программам, которые используют 
СОМѴЕРТ . Программа не должна зависеть от существования пробела. 

См.: 3.3.3.6 Другие временные области, 3.4.1 Синтаксический анализ. 

6.1.2490 ХОР "х-ог" СОРЕ 

( хі х2 -- хЗ ) 

хЗ поразрядное исключающее-или хі и х2. 

6.1.2500 [ "ІеП-ЬгаскеІ" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: Исполняет семантику выполнения, данную ниже. 

Выполнение: ( -- ) 

Вводит состояние интерпретации. [ - слово немедленного выполнения. 

См.: 3.4 Интерпретатор текста РогІІі, 3.4.5 Компиляция, 6.1.2540 ]. 

6.1.2510 ['] "Ьгаскеі-Ііск" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "<зрасе5>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Находит пате. Добавляет семантику времени-выполнения, 
данную ниже к текущему определению. 

Неопределенная ситуация существует, если пате не найдено. 
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Время-выполнения: ( -- хі ) 

Помещает идентификатор исполнения пате хі на стек. Идентификатор 
исполнения, возвращенный скомпилированной фразой "['] X " , имеет 
то же значение, как и возвращенный X " вне состояния компиляции. 

См.: 3.4.1 Синтаксический анализ, А.6.1.0070 ', А.6.1.2033 Р05ТР0ИЕ, 
0.6.7 Іттесііаіе-ности . 

6.1.2520 [СНАР] "Ьгаскеі-сбаг" СОРЕ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "<зрасе5>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Добавляет семантику времени-выполнения, данную ниже к 
текущему определению. 

Время-выполнения: ( -- сПаг ) 

Помещает на стек сііаг, значение первого символа пате. 

См.: 3.4.1 Синтаксический анализ, 6.1.0895 СНАР. 

6.1.2540 ] "гідПІ-ЬгаскеІ" СОРЕ 

( -- ) 

Вводит состояние компиляции. 

См.: 3.4 Интерпретатор текста РогІИ, 3.4.5 Компиляция, 6.1.2500 [. 
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6.2 



Расширения основных слов 


6.2.0060 

#ТІВ 

"питЬег-І-і-Ь" 

СОРЕ ЕХТ 


( -- а-асісіг ) 




а-асісіг - адрес ячейки, содержащей число символов во входном буфере 
терминала. 

Примечание: Это слово устаревшее и включено как уступка существующим 
реализациям. 

6.2.0200 .( "сіоі-рагеп" СОРЕ ЕХТ 

Компиляция: Исполняет семантику выполнения, данную ниже. 

Выполнение: ( "ссс<рагеп>" -- ) 

Выделяет и отображает ссс, ограниченную ) (правая круглая скобка). 

.( является словом немедленного исполнения. 

См.: 3.4.1 Синтаксический анализ, 6.1.0190 .". 


6.2.0210 

. Р 



"сіоі-г" 

СОРЕ ЕХТ 


( ПІ 

п2 -- ) 





Отображает п1 

выровненное вправо в поле шириной п2 символов. Если 


ЧИСЛО 

символов требуемых для отображения п1 больше чем п2, 

все 


цифры отображаются 

без ведущих пробелов в поле необходимой 

ширины. 

6.2.0260 

Ѳ<> 



"гего-поі-едиаіз" 

СОРЕ ЕХТ 


( х - 

- Тіад ) 





-Гіад 

- іше, 

если 

и только если х - не равно нулю. 


6.2.0280 

Ѳ> 



"гего-дгеаіег" 

СОРЕ ЕХТ 


( п - 

- 1=1ад ) 





Пад 

- Ігие, 

если 

и только если п - больше нуля. 


6.2.0340 

2>Р 



"Іио-Іо- г" 

СОРЕ ЕХТ 


Интерпретация: Семантика интерпретации для этого слова не определена. 


Выполнение: ( хі х2 -- ) ( Р: -- хі х2 ) 

Перемещает пару-ячеек хі х2 на стек возвратов. Семантически 
эквивалентно 5\л/АР >Р >Р. 

См.: 3.2.3.3 Стек возвратов, 6.1.0580 >Р, 6.1.2060 Р>, 6.1.2070 Р@, 
6.2.0410 2Р>, 6.2.0415 2Р@. 

6.2.0410 2Р> "ІілЮ-Г-Тгот" СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: ( -- хі х2 ) ( Р: хі х2 -- ) 

Перемещает пару-ячеек хі х2 со стека возвратов. Семантически 
эквивалентно Р> Н> 5Ѵ\/АР. 
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См.: 3.2.3.3 Стек возвратов, 6.1.0580 >Н, 6.1.2060 Р>, 6.1.2070 Р@, 
6.2.0340 2>Р, 6.2.0415 2Н@. 

6.2.0415 2Р§ 'Чіл/О-Г-ТеІсИ" СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: ( -- хі х2 ) ( Р: хі х2 -- хі х2 ) 

Копирует пару-ячеек хі х2 со стека возвратов. Семантически 
эквивалентно Р> Р> 201ІР >Р >Р 5МАР. 



См.: 3.2.3.3 Стек возвратов, 6.1.Ѳ58Ѳ >Р, 6.1.2060 Р>, 6.1.2070 Р@, 
6.2.0340 2>Р, 6.2.0410 2Р>. 

6.2.0455 : ІМОІМАМЕ "соіоп - по-пате" СОРЕ ЕХТ 

(С: -- соіоп-зуз ) (5: -- хі ) 

Создает идентификатор исполнения хі, вводит состояние компиляции и 
начинает текущее определение, производя соіоп-зуз. Добавляет 
семантику инициирования данную ниже к текущему определению. 

Семантика выполнения хі будет определена скомпилированными в тело 
определения словами. Это определение может быть выполнено позже, 
используя хі ЕХЕСІІТЕ . 

Если стек потока управления реализован с использованием стека 
данных, соіоп-зуз должен быть самым верхним элементом на стеке 
данных. 

Инициирование: ( і*х -- і*х ) ( Р: -- пезі-зуз ) 

Сохраняет зависящую-от-реализации информацию пезі-зуз о вызывающем 
определении. Состояние стека і*х представляет параметры для хі . 

хі Выполнение: ( і*х -- д*х ) 

Выполняет определение определенное хі . Состояние стека і*х и і*х 
представляет параметры для и результаты от хі, соответственно. 


См. 3.2.3.2 Стек потока-управления. 


6.2.0500 

о 

"поі-едиаіз" 

СОРЕ 

ЕХТ 


( х1 х2 -- Тіад ) 





Тіад - Ігие, если 

и только если хі побитно не 

эквивалентно х2. 


6.2.0620 

?Р0 

"диезііоп-бо" 

СОРЕ 

ЕХТ 


Интерпретация: Семантика интерпретации для этого слова не определена. 


Компиляция: (С: -- сіо-зуз ) 

Помещает сіо-зуз на стек потока управления. Добавляет семантику 
времени-выполнения данную ниже к текущему определению. Семантика не 
завершена, пока не разрешена потребителем сіо-зуз типа 1_00Р. 

Время-выполнения: ( п1[и1 п2|и2 -- ) ( К: -- | Іоор-зуз ) 
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Если п1|и1 равно п2|и2, продолжает выполнение с адреса ячейки 
данного потребителем сіо-зуз. Иначе устанавливает параметры 
управления цикла с индексом п2|и2, и границей п1|и1, и продолжает 
выполнение непосредственно после ?00. Что - либо уже имеющееся на 
стеке возвратов становится недоступным до удаления параметров 
управления циклом. Неопределенная ситуация существует, если оба 
п1|и1 и п2|и2- не одного типа. 

См.: 3.2.3.2 Стек потока-управления, 6.1.0140 +1_00Р, 6.1.1240 00, 
6.1.1680 I, 6.1.1760 І_ЕАѴЕ, 6.1.1800 Ц00Р, 6.1.2380 ІІІЧІ.00Р. 

6.2.0700 АСАІІ\| СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: сіезі: -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению, разрешением ссылки назад без!. 


Время-выполнения: ( -- ) 

Продолжает выполнение с адреса ячейки определенного без!. Если 



никакое другое слово потока управления не используется, любой код 
программы после АСАІМ не будет выполнен. 

См.: 6.1.0760 ВЕ6ІМ. 

6.2.0855 С" "С-Діюіе" СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "ссс<цио1:е>" -- ) 

Выделяет ссс, ограниченное " (двойная кавычка), и добавляет 
семантику времени-выполнения данную ниже к текущему определению. 

Время-выполнения: ( -- с-асісіг ) 

Возвращает с-аббг строку со счетчиком, состоящую из символов ссс. 
Программа не должна изменять возвращенную строку. 

См.: 3.4.1 Синтаксический анализ, 6.1.2165 5", 11.6.1.2165 5". 

6.2.0873 САЗЕ СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: (С: -- сазе-зуз ) 

Отмечает начало САЗЕ ... ОР ... ЕШОР . . . ЕШСА5Е структуры. 
Добавляет семантику времени-выполнениия, данную ниже к текущему 
определению . 

Время-выполнения: ( -- ) 

Продолжает выполнение. 

См.: 6.2.1342 ЕШСА5Е, 6.2.1343 ЕШОР, 6.2.1950 ОР. 

6.2.0945 СОМРІІ_Е, "сотрііе-сотта" СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 
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Выполнение: ( хі -- ) 

Добавляет семантику выполнения определения представленного хі к 
семантике выполнения текущего определения. 

6.2.0970 СОИѴЕРТ СОРЕ ЕХТ 

( исіі с-асісігі -- исІ2 с-асІсІг2 ) 

исІ2 - результат преобразования символов в пределах текста 
начинающегося с первого символа после с-асісігі в цифры, используя 
число из ВАЗЕ, и добавление каждой цифры в исіі после умножения исіі 
на число из ВАЗЕ. Преобразование продолжается до встречи с не 
преобразуемым символом. с-асІсІг2 - адрес ячейки первого не 
преобразованного символа. Неопределенная ситуация существует, если 
исІ2 переполняется. 

Примечание: Это слово устаревшее и включено как уступка существующим 
реализациям. Его функция заменена на 6.1.0570 >І\ІІІМВЕН. 

См.: 3.2.1.2 Преобразование цифр. 

6.2.1342 ЕШСА5Е "епсі-сазе" СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: сазе-зуз -- ) 

Отмечает конец САЗЕ ... ОР ... ЕШОР . . . ЕШСА5Е структуры. 
Использует сазе-зуз для разрешения всей структуры. Добавляет 
семантику времени-выполнения данную ниже к текущему определению. 



Время-выполнения: ( х -- ) 

Снимает сазе селектор х, и продолжает выполнение. 

См.: 6.2.0873 САЗЕ, 6.2.1343 ЕШОР, 6.2.1950 ОР. 

6.2.1343 ЕШОР "епб-оТ" СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: сазе-зузі оТ-зуз -- сазе-зуз2 ) 

Отмечает конец ОР . . . ЕШОР части САЗЕ структуры. Следующий адрес 
ячейки для передачи управления разрешает ссылка о'Р-зуз. Добавляет 
семантику времени-выполнения, данную ниже к текущему определению. 
Заменяет сазе-зузі на сазе-зуз2 на стеке потока управления, для 
разрешения ЕШСА5Е. 

Время-выполнения: ( -- ) 

Продолжает выполнение с адреса ячейки определенного потребителем 
сазе-зуз2. 

См.: 6.2.0873 САЗЕ, 6.2.1342 ЕШСА5Е, 6.2.1950 ОР. 

6.2.1350 ЕРАЗЕ СОРЕ ЕХТ 

( абсіг и -- ) 

Если и больше нуля, очистить все биты в каждом из и 
последовательных адресуемых элементов памяти, начинающихся с абсіг. 
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6.2.1390 ЕХРЕСТ СОРЕ ЕХТ 

( с-асісіг +п -- ) 

Получает строку с максимумом в +п символов. Отображает графические 
символы по мере их получения. Программа, которая зависит от 
присутствия или отсутствия неграфических символов в строке имеет 
зависимость от окружения. Функции редактирования, если таковые 
вообще имеются, которые система исполняет, чтобы создать строку 
символов - определенное реализацией. 

Ввод заканчивается, когда получен определенный реализацией признак 
конца строки или если строка длиной +п символов. Когда ввод 
заканчивается, ничего не добавляется в конец строки, и изображение 
обеспечивается определенным реализацией способом. 

Сохраняет строку в с-асісіг и ее длинну в 5РАІМ . 

Примечание: Это слово устаревшее и включено как уступка существующим 
реализациям. Его функция заменена на 6.1.0695 АССЕРТ. 

6.2.1485 РАІ_5Е СОРЕ ЕХТ 

( -- Таізе ) 

Возвращает флаг Таізе. 

См.: 3.1.3.1 Флаги 

6.2.1660 НЕХ СОРЕ ЕХТ 

( -- ) 

Устанавливает содержимое ВАЗЕ в 16. 

6.2.1850 МАРКЕР СОРЕ ЕХТ 

( "<зрасез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения, 
определенной ниже. 



пате Выполнение: ( -- ) 

Восстанавливает все распределение словаря и указатели порядка 
поиска на состояние, которое они имели непосредственно до 
определения пате. Удаляет определение пате и все последующие 
определения. Восстановление любых все еще существующих структур, 
которые могли бы обратиться к удаленным определениям или 
освобожденной области данных предусматривать не обязательно. 
Никакая другая контекстная информация типа основания счисления не 
затрагивается. 

См.: 3.4.1 Синтаксический анализ, 15.6.2.1580 РОРСЕТ. 


6.2.1930 

І\ІІР 

СОРЕ 

ЕХТ 


( хі х2 - - х2 ) 

Удаляет первый элемент ниже вершины стека. 



6.2.1950 

ОР 

СОРЕ 

ЕХТ 


Интерпретация: Семантика интерпретации для этого слова не определена. 
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Компиляция: (С: -- оТ-зуз ) 

Помещает оТ-зуз на стек потока управления. Добавляет семантику 
времени-выполнения данную ниже к текущему определению. Семантика не 
завершена, пока не разрешена оТ-зуз потребителем типа ЕШОР. 

Время-выполнения: ( хі х2 -- | хі ) 

Если два значения на стеке - не равны, снимает верхнее значение и 
продолжает выполнение с адреса ячейки определенного потребителем 
оТ-зуз, например, после следующего ЕШОР. Иначе, снимает оба 
значения и продолжает выполнение в строке. 

См.: 6.2.0873 САЗЕ, 6.2.1342 ЕШСА5Е, 6.2.1343 ЕШОР. 

6.2.2000 РАО СОРЕ ЕХТ 

( -- с-асібг ) 

с-асісіг - адрес временной области, которая может использоваться с 
целью хранения данных для промежуточной обработки. 

См.: 3.3.3.6 Другие временные области. 

6.2.2008 РАРЗЕ СОРЕ ЕХТ 

( сбаг "ссс<сбаг>" -- с-асісіг и ) 

Выделяет ссс, ограниченную разделителем сбаг. 

с-асісіг - адрес (в пределах входного буфера) и и - длина выделенной 
строки. Если область анализа была пуста, результирующая строка 
имеет нулевую длину. 

См.: 3.4.1 Синтаксический анализ. 

РІСК СОРЕ ЕХТ 

(хи ... хі хѲ и -- хи ... хі хО хи ) 

Удаляет и. Копирует хи на вершину стека. Неопределенная ситуация 
существует, если до выполнения РІСК на стеке меньше и+2 элементов. 

фІІЕРѴ СОРЕ ЕХТ 

( -- ) 

Делает пользовательское устройство ввода данных входным источником. 
Получает ввод в буфер ввода терминала, заменяя любое предыдущее 
содержимое. Делает результат, чей адрес возвращается ТІВ, входным 
буфером. Установить >ІМ в ноль. 


6.2.2030 


6.2.2040 



Примечание: Это слово устаревшее и включено как уступка существующим 
реализациям. 

6.2.2125 РЕРІШ СОРЕ ЕХТ 

( -- -Лад ) 
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Пытается заполнить входной буфер из входного источника, возвращая 
Іше "Лад если успешно. 

Если входной источник - пользовательское устройство ввода, пытается 
получить ввод во входной буфер терминала. Если успешно, делает 
результат входным буфером, устанавливает >ІМ в ноль, и возвращает 
Ігие. Получение строки не содержащей никакие символы 
рассматривается успешным. Если ввод не доступен из текущего 
входного источника, возвращает Таізе . 

Когда входной источник - строка от ЕѴАШАТЕ, возвращает Таізе и не 
исполняет никакое другое действие. 

См.: 7.6.2.2125 РЕРІШ, 11.6.2.2125 РЕРІШ. 

6.2.2148 РЕ5Т0РЕ- ІМРІІТ СОРЕ ЕХТ 

( хп ... хі п - - Лад ) 

Пытается восстановить спецификацию входного источника к состоянию 
описанному хі ... хп. Лад - Тгие, если спецификация входного 
источника не может быть так восстановлена. 

Неопределенная ситуация существует если входной источник, 
представленный параметрами - не совпадает с текущим входным 
источником. 

См.: А.6.2.2182 ЗАУЕ-ІИРбТ. 

РОШ СОРЕ ЕХТ 

( хи хи-1 ... хО и -- хи-1 ... хО хи ) 

Удаляет и. Вращает и+1 элементов на вершине стека. Неопределенная 
ситуация существует, если перед выполнением РОШ на стеке имелось 
меньше и+2 элементов. 

5АѴЕ-ІМРІІТ СОРЕ ЕХТ 

( -- ХП ... ХІ п ) 

хі ... хп описывают текущее состояние спецификации входного 
источника для более позднего использования РЕ5Т0РЕ-ІИРІІТ. 

50ЦРСЕ-Ю "зоигсе-і-сі" СОРЕ ЕХТ 

( -- 0 | -1 ) 

Идентифицирует входной источник следующим образом: 

501ІРСЕ-Ю Входной источник 


-1 Строка (через ЕѴАШАТЕ) 

О Пользовательское устройство ввода 


6.2.2150 


6.2.2182 


6.2.2218 


См.: 11.6.1.2218 БОбРСЕ-Ю. 

6.2.2240 5РАИ СОРЕ ЕХТ 

( -- а-асібг ) 

а-асісіг - адрес ячейки, содержащей число символов сохраненное 
последним выполнением ЕХРЕСТ. 
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Примечание: Это слово устаревшее и включено как уступка существующим 
реализациям. 

6.2.2290 ТІВ "б-І-Ь" СОРЕ ЕХТ 

( -- с-асісіг ) 

с-асісіг - адрес буфера ввода терминала. 

Примечание: Это слово устаревшее и включено как уступка существующим 
реализациям. 

6.2.2295 ТО СОРЕ ЕХТ 

Интерпретация: ( х "<5расе5>пате" -- ) 

Пропускает ведущие пробелы, и выделяет пате, ограниченное пробелом. 
Сохраняет х в пате. Неопределенная ситуация существует, если пате 
не было определено через ѴАШЕ. 

Компиляция: ( "<зрасе5>пате" -- ) 

Пропускает ведущие пробелы, и выделяет пате, ограниченное пробелом. 
Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. Неопределенная ситуация существует, если пате не было 
определено через ѴАШЕ. 

Время-выполнения: ( х -- ) 

Сохраняет х в пате. 

Примечание: Неопределенная ситуация существует, если Р05ТР0ИЕ или 
[С0МРІ6Е] , применяется к ТО. 

См.: 6.2.2405 ѴАШЕ, 13.6.1.2295 ТО . 

6.2.2298 ТРІІЕ СОРЕ ЕХТ 

( -- бше ) 

Возвращает флаг бгие, значение одна-ячейка со всеми установленными 
битами. 

См.: 3.1.3.1 Флаги. 

6.2.2300 ТІІСК СОРЕ ЕХТ 

( хі х2 -- х2 хі х2 ) 

Копирует верхний элемент стека ниже второго элемента стека. 

6.2.2330 II.Р "и-сіоб-г" СОРЕ ЕХТ 

( и п -- ) 

Отображает и выровненное вправо, в поле шириной п символов. Если 
число символов требуемых для отображения и больше чем п, все цифры 
отображаются без ведущих пробелов в поле необходимой ширины. 

6.2.2350 ІІ> "и-дгеабег-ббап" СОРЕ ЕХТ 

( иі и2 -- Тіад ) 

Тіад - бгие, если и только если иі больше чем и2. 

См.: 6.1.0540 >. 
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6.2.2395 ІШ5Е0 СОРЕ ЕХТ 

( -- и ) 

и - количество оставшегося пространства в области адресуемой НЕРЕ, 
в адресуемых элементах. 


6.2.2405 ѴАШЕ 


СОРЕ ЕХТ 



( х "<5расе5>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения, 
определенной ниже, с начальным значением равным х. 

пате определено как "ѵаіие". 

пате Выполнение: ( -- х ) 

Помещает х на стек. Значение х - то что задано, при создании пате, 
до тех пор пока не выполнена фраза х ТО пате, задающая новое 
значение х, связанное с пате. 

См.: 3.4.1 Синтаксический анализ. 

\л/ІТНІМ СОРЕ ЕХТ 

( п1|и1 п2|и2 пЗ|иЗ -- Тіад ) 

Выполняет сравнение проверяемого значения п1|и1 с нижним пределом 
п2|и2 и верхним пределом пЗ|иЗ, возвращая Іше, если (п2|и2 < пЗ|иЗ 
и (п2|и2 <= п1|и1 и п1|и1 < пЗ|иЗ)) или (п2|и2 > пЗ|иЗ и (п2|и2 <= 
п1|и1 или п1|и1 < пЗ|иЗ)) - Іше, иначе возвращает Таізе. 
Неопределенная ситуация существует, если п1|и1, п2|и2, и пЗ|иЗ не 
все одного типа. 

[СОМРІБЕ] "Ьтаске! -сотрііе" СОРЕ ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "<зрасе5>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Находит пате. Если пате имеет семантику компиляции 
отличную от заданной по умолчанию, добавляет ее к текущему 
определению; иначе добавляет семантику выполнения пате. 
Неопределенная ситуация существует, если пате не найдено. 

См.: 3.4.1 Синтаксический анализ. 

6.2.2535 \ "Ьаскзіазіі" СОРЕ ЕХТ 

Компиляция: Исполняет семантику выполнения, данную ниже. 

Выполнение: ( "ссс<ео1>"-- ) 

Выделяет и удаляет остаток области анализа. \ слово немедленного 
исполнения. 

См.: 7.6.2.2535 \. 


6.2.2440 


6.2.2530 
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7. _ 

Дополнительный Блочный набор слов 

7.1 _ 

Введение 

7.2 _ 

Дополнительные термины 

Блок: 1024 символа данных на запоминающем устройстве, обозначенные номером 
блока. 

Блочный буфер: зона области данных блочного размера, где блок создан временно 
доступным для использования. Текущий блочный буфер - блочный буфер больше всего 
недавно использовавшийся посредством В1_0СК, ВІІРРЕР, 1_0А0, І_І5Т, или ТНРІІ. 


7.3 



Дополнительные условия применения 


7.3.1 _ 

Запросы к окружению 

Добавьте таблицу 7.1 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 7.1 - Строки запросов к окружению 

Строка Тип Константа Значение 


ВЦОСК "Лад по блочный набор слов присутствует 

ВЦОСК-ЕХТ "Лад по дополнительный блочный набор слов 

присутствует 


7.3.2 _ 

Область данных 

Программа может обращаться к памяти в пределах блочного буфера. 

См.: 3.3.3 Область данных. 

7.3.3 _ 

Области блочного буфера 

Адрес блочного буфера, возвращенного ВЦОСК или ВЦІРРЕР временный. Вызов ВЦОСК 

или ВЦІРРЕР может сделать адрес предварительно полученного блочного буфера 

недействительным, также как вызов любого слова типа: 

- синтаксические анализаторы; 

- отображающие символы на пользовательском устройстве вывода, типа ТУРЕ или 
ЕМІТ ; 

- управляющие пользовательским устройством вывода, типа СР или АТ-ХУ; 

- получающие или проверяющие на присутствие символов из пользовательского 
устройства ввода, типа АССЕРТ или КЕУ; 

- ждущие состояние или событие, типа М5 или ЕКЕУ; 

- управляющие блочными буферами, типа РЦЦІ5Н, 5АѴЕ-ВЦІРРЕР5, или ЕМРТУ-ВЦІРРЕР5; 

- выполняющие любую операцию над файлом или каталогом имени файла, которые 
подразумевают ввод-вывод, типа РЕРШЦ или любое слово, которое возвращает 
іог; 

- неявно выполняющие ввод-вывод, типа встроенного и не встроенного текстового 
интерпретатора при использовании файлов (включая не встроенный 
подразумеваемый ТНРО\л/) . 
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Если входной источник - блок, эти ограничения также относятся к адресу, 
возвращенному 50ЦІРСЕ. 

Блочные буферы уникально назначены на блоки. 

7.3.4 _ 

Синтаксический анализ 

Блочный набор слов обеспечивает альтернативный входной источник для текстового 
интерпретатора. Когда входной источник - блок, ВЕК должен содержать ненулевой 
номер блока и входной буфер - 1024-символьный буфер, содержащий этот блок. 

Блок традиционно представлен как 16 строк по 64 символа. 





Программа может переключать входной источник на блок, используя І_ОАР или ТНПІІ. 
Входные источники могут быть вложены, используя І_ОАР, и ЕѴАШАТЕ в любом 
порядке . 

Программа может переустанавливать область анализа в пределах блока, управляя 
>ІМ. Более обширное переустановление может быть выполнено, используя 5АѴЕ-ІИРІІТ 
и РЕЗТОРЕ-ІИРІІТ. 

См.: 3.4.1 Синтаксический анализ. 

7.3.5 _ 

Возможное действие на неопределенную ситуацию 

См.: 3.4.4 Возможное действие на неопределенную ситуацию. 

- Система с блочным набором слов может устанавливать состояние интерпретации и 
интерпретировать блок. 

7.4 _ 

Дополнительные документационные требования 

7.4.1 _ 

Системная документация 

7.4.1.1 _ 

Опции определенные реализацией 

- формат, используемый для отображения с помощью 7.6.2.1770 І_І5Т (если 
реализовано); 

- длина строки, поддерживаемая 7.6.2.2535 \ (если реализовано). 

7.4.1.2 _ 

Неопределенные ситуации 

- Верное чтение блока не было возможно; 

- Исключение ввода-вывода при пересылке блока; 

- Недействительный номер блока (7.6.1.0800 В1_0СК, 7.6.1.0820 ВІІРРЕР, 7.6.1.1790 
1_0А0); 

- Программа непосредственно изменяет содержимое 7.6.1.0790 ВІ_К; 

- Нет текущего блочного буфера для 7.6.1.2400 ІІРОАТЕ. 

7.4.1.3 _ 

Другая системная документация 

- любые ограничения служб системы мультипрограммирования на использование 
адресов буферов; 

- число блоков, доступных для исходного текста и данных. 

7.4.2 _ 

Программная документация 

- число блоков, требуемых программой. 
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7.5 _ 

Соглашение и наименование 

7.5.1 _ 

А№ Рогіб системы 


Фраза "Предоставляет блочный набор слов" должна быть добавлена к наименованию 



любой Стандартной системы, которая предоставляет весь блочный набор слов. 


Фраза "Предоставляет имена из расширения блочного набора слов" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет часть 
расширения блочного набора слов. 

Фраза "Предоставляет расширение блочного набора слов" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь блочный 
набор слов и расширение блочного набора слов. 

7.5.2 _ 

А№ РогІП программы 

Фраза "Требуется блочный набор слов" должна быть добавлена к наименованию 
Стандартной программы, которая требует, чтобы система предоставила блочный 
набор слов. 

Фраза "Требуются имена из расширения блочного набора слов" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения блочного набора слов. 

Фраза "Требуется расширение блочного набора слов" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь блочный набор слов и расширение блочного набора слов. 

7.6 _ 

Словарь 

7.6.1 _ 

Блочные слова 

7.6.1.0790 ВІ_К "Ь-1-к" В1_0СК 

( -- а-асісіг ) 

а-асісіг - адрес ячейки, содержащей нуль или номер интерпретируемого 
блока запоминающего устройства. Если ВІ_К содержит нуль, входной 
источник - не блок и может быть идентифицирован 501ІПСЕ-Ю, если 
501ІРСЕ-Ю является доступным. Неопределенная ситуация существует 
если программа непосредственно изменяет содержание ВІ_К. 

См.: 7.3.3 Области блочного буфера. 

7.6.1.0800 ВБОСК ВЮСК 

( и -- а-асісіг ) 

а-асісіг - адрес первого символа блочного буфера назначенного на блок 
и запоминающего устройства. Неопределенная ситуация существует, 
если и не доступный номер блока. 

Если блок и - уже в блочном буфере, а-асісіг - адрес этого блочного 
буфера. 


75 


Если блок и - уже не в памяти и есть свободный блочный буфер, 
перемещает блок и из запоминающего устройства в свободный блочный 
буфер, а-асісіг - адрес этого блочного буфера. 

Если блок и - уже не в памяти и нет никаких свободных блочных 
буферов, освобождает блочный буфер. Если для блока в этом буфере 
было выполнено ІІРОАТЕ, перемещает блок в запоминающее устройство, и 
перемещает блок и из запоминающего устройства в этот буфер, а-асісіг 
- адрес этого блочного буфера. 

При завершении операции, блочный буфер указанный а-асісіг - текущий 



буфер блоков и назначен на и. 


7.6.1.0820 


См. 

7.6.1.1360 

7.6.1.1559 

7.6.1.1790 


См. 

7.6.1.2180 

7.6.1.2400 


ВІІРРЕР В1_0СК 

( и -- а-асісіг ) 

а-асісіг - адрес первого символа блочного буфера назначенного блоку 
и. Содержание блока не определено. Неопределенная ситуация 
существует, если и - не доступный номер блока. 

Если блок и - уже в блочном буфере, а-асісіг - адрес этого блочного 
буфера. 

Если блок и - уже не в памяти и есть свободный буфер, а-асісіг - 
адрес этого блочного буфера. 

Если блок и - уже не в памяти и нет никаких свободных блочных 
буферов, освобождает блочный буфер. Если для блока в этом буфере 
было выполнено ІІРОАТЕ, перемещает блок в запоминающее устройство, 
а-асісіг - адрес этого блочного буфера. 

При завершении операции, блочный буфер указанный а-асісіг - текущий 
буфер блоков и назначен на и. 

7.6.1.0800 ВШСК. 

ЕѴАШАТЕ ВШСК 

Расширяется семантика 6.1.1360 ЕѴАШАТЕ так, чтобы включить: 

Запись нуля в ВІ_К. 

РШ5Н ВЮСК 

( -- ) 

Выполняет функцию 5АѴЕ-ВІІРРЕП5, затем освобождает все блочные 
буферы. 

ШАО ВШСК 

( і * х и -- ^ * х ) 

Сохраняет текущую спецификацию входного источника. Записывает и в 
ВІ_К (таким образом делает блок и входным источником, и 
устанавливает входной буфер в соответствии с его содержимым), 
обнуляет >ІІ\І, и интерпретирует. Когда область анализа исчерпана, 
восстанавливает предыдущую спецификацию входного источника. Другое 
состояние стека из-за интерпретации слов с помощью ЮАО. 
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Неопределенная ситуация существует, если и нулевой или - не 
допустимый номер блока. 

3.4 Интерпретатор текста Рогіб. 

5АѴЕ-ВІІРРЕК5 ВШСК 

( -- ) 

Перемещает содержание каждого модифицированного блочного буфера на 
запоминающее устройство. Отмечает все буферы как не 
модифицированные. 

ІІРОАТЕ ВШСК 

( -- ) 

Отмечает текущий блочный буфер как измененный. Неопределенная 
ситуация существует, если нет никакого текущего блочного буфера. 

ІІРОАТЕ не вызывает немедленно ввод-вывод. 



См.: 7.6.1.Ѳ8Ѳ0 ВЮСК, 7.6.1.082Ѳ ВІІРРЕК, 7.6.1.1559 РШ5Н, 7.6.1.2180 
5АѴЕ-ВІІРРЕР5 . 

7.6.2 _ 

Расширения блочных слов 

7.6.2.1330 ЕМРТѴ-ВІІРРЕР5 ВЮСК ЕХТ 

( -- ) 

Освобождает все блочные буферы. Не перемещает содержание никакого 
модифицированного блочного буфера на запоминающее устройство. 

См. : 7.6.1.Ѳ800 ВЮСК. 

7.6.2.1770 І_І5Т ВЮСК ЕХТ 

( и -- ) 

Отображает блок и в формате определенном реализацией. Сохраняет и в 
5СР. 

См. : 7.6.1.0800 ВЮСК. 

7.6.2.2125 РЕРІШ ВЮСК ЕХТ 

( -- -Лад ) 

Расширяется семантика выполнения 6.2.2125 РЕРІШ следующим образом: 

Когда входной источник - блок, делает следующий блок входным 
источником и текущим входным буфером, добавляя один к значению ВІ_К 
и устанавливая >ІМ в ноль. Возвращает Іше, если новое значение В1_К 
- допустимый номер блока, иначе Таізе. 

См.: 6.2.2125 РЕРІЮ, 11.6.2.2125 РЕРІШ. 

7.6.2.2190 5СР " 5 - С - г" ВЮСК ЕХТ 

( -- а-асісіг ) 

а-асісіг - адрес ячейки, содержащей номер последнего блока 
отображенного с помощью І_І5Т . 
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7.6.2.2280 ТНКІІ ВЮСК ЕХТ 

( і *х иі и2 -- д*х ) 

ЦОАО последовательные блоки из запоминающего устройства с номерами 
с иі по и2. Другое состояние стека из-за интерпретации слов с 
помощью ЦОАО. 

7.6.2.2535 \ "ЬаскзІазМ" ВЦОСК ЕХТ 

Компиляция: Исполняет семантику выполнения, данную ниже. 

Выполнение: ( "ссс<ео1>"-- ) 

Если ВІ_К содержит нуль, выделяет, и удаляет остаток области 
анализа; иначе выделяет, и удаляет остаток области анализа 
соответствующей остатку текущей строки. \ - слово немедленного 
исполнения. 
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8 . _ 

Дополнительный набор слов двойных чисел 

8.1 _ 

Введение 


16-бит системы РогІИ часто используют числа двойной длины. Однако много РогІІі- 



ов на маленьких встроенных системах этого не имеют, и много пользователей РогИп 
на системах с размером ячейки 32 бит или больше находят, что использование 
чисел двойной длины очень ограничено. Поэтому слова, которые манипулируют 
объектами двойной длины, были помещены в этот дополнительный набор слов. 

8.2 _ 

Дополнительные термины и нотации 


Нет. 

8.3 _ 

Дополнительные условия применения 

8.3.1 _ 

Запросы к окружению 

Добавьте таблицу 8.1 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 8.1 - Строки запросов к окружению 

Строка Тип Константа Значение 


Р01ІВІ_Е "Лад по набор слов двойных чисел присутствует 

РОІІВЦЕ-ЕХТ "Лад по дополнительный набор слов двойных чисел 

присутствует 


8.3.2 _ 

Преобразование входных чисел текстового интерпретатора 

Когда текстовый интерпретатор обрабатывает число, которое непосредственно 
сопровождается десятичной точкой и не найдено как определение пате, текстовый 
интерпретатор должен преобразовать его к числу две-ячейки. 

Например, ввод ОЕСІМАІ_ 1234 оставит число одна-ячейка 1234 на стеке, и ввод 
ОЕСІМАЦ 1234. оставит число две-ячейки 1234 0 на стеке. 

См.: 3.4.1.3 Преобразование входных чисел текстового интерпретатора. 

8.4 _ 

Дополнительные документационные требования 

8.4.1 _ 

Системная документация 

8.4.1.1 Опции определенные реализацией 

- нет дополнительных требований. 

8.4.1.2 Неопределенные ситуации 

- сі вне диапазона п при 8.6.1.1140 0>5. 

8.4.1.3 Другая системная документация 

- нет дополнительных требований. 
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8.4.2 





Программная документация 
- нет дополнительных требований. 

8.5 _ 

Соглашение и наименование 

8.5.1 _ 

А№ РогІИ системы 

Фраза "Предоставляет набор слов двойных чисел" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов 
двойных чисел. 

Фраза "Предоставляет имена из расширения набора слов двойных чисел" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет часть 
расширения набора слов двойных чисел. 

Фраза "Предоставляет расширение набора слов двойных чисел" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет весь 
набор слов двойных чисел и расширение набора слов двойных чисел. 

8.5.2 _ 

А№ РогІИ программы 

Фраза "Требуется набор слов двойных чисел" должна быть добавлена к наименованию 
Стандартной программы, которая требует, чтобы система предоставила набор слов 
двойных чисел. 

Фраза "Требуются имена из расширения набора слов двойных чисел" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения набора слов двойных чисел. 

Фраза "Требуется расширение набора слов двойных чисел" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь набор слов двойных чисел и расширение набора слов двойных чисел. 

8.6 _ 

Словарь 

8 . 6.1 _ 

Слова двойных чисел 

8.6.1.0360 2С0М5ТАІМТ "Іио-СОПЗІіапІ:" 001ІВ1.Е 

( хі х2 "<5расез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения, 
определенной ниже. 

пате объявляется как "Іио-сопзііапі:" . 

пате Выполнение: ( -- хі х2 ) 

Помещает пару-ячеек хі х2 на стек. 

См.: 3.4.1 Синтаксический анализ. 
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8.6.1.0390 2І_ІТЕКАІ_ "Шл/О-ІІІегаІ" 001ІВІ_Е 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( хі х2 -- ) 

Добавляет семантику времени-выполнения данную ниже к текущему 



определению. 


Время-выполнения: ( -- хі х2 ) 

Помещает пару-ячеек хі х2 на стек. 

8.6.1.Ѳ44Ѳ 2ѴАКІАВЕЕ 'Чио-ѵагіаЫе" ООЦВЦЕ 

( "<зрасез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения, 
определенной ниже. Резервирует две последовательных ячейки области 
данных. 

пате объявляется как "Іио-ѵагіаЫе" . 

пате Выполнение: ( -- а-асісіг ) 

а-асісіг - адрес первой (наименьший адрес) ячейки двух 
последовательных ячеек в области данных, зарезервированной 
2ѴАРІАВЦЕ, когда оно определило пате. Программа ответственна за 
инициализацию содержимого. 

См.: 3.4.1 Синтаксический анализ, 6.1.2410 ѴАРІАВЦЕ. 

8.6.1.1Ѳ4Ѳ 0+ "сі-ріиз" 001ІВ1_Е 

( сіі | исіі сІ2 | исІ2 -- сІЗ | исІЗ ) 

Добавляет сІ2|исІ2 к сІ1|исІ1, возвращает сумму сІЗ | исІЗ . 

8.6.1.1Ѳ5Ѳ 0 - "сі-тіпиз" ООЦВЦЕ 

( сіі | исіі сІ2 | исІ2 -- сІЗ | исІЗ ) 

Вычитает сІ2|исІ2 из сіі | исіі, возвращает разницу сІЗ | исІЗ . 

8.6.1.1060 0. "сі-сіоі" ООЦВЦЕ 

( 0 -- ) 

Отображает сі в формате свободного поля. 

8.6.1.1070 О.Р "сі-сіоі-г" ООЦВЦЕ 

( 0 п -- ) 

Отображает сі выровненное вправо в поле шириной п символов. Если 
число символов требуемых для отображения сі больше чем п, все цифры 
отображаются без ведущих пробелов в поле необходимой ширины. 

8.6.1.1075 О0< "сі-гего-іезз" ООЦВЦЕ 

( сі -- -Гіад ) 

Гіад - Гше, если и только если сі - меньше нуля. 

8.6.1.1080 00= "сі-гего-едиаіз" ООЦВЦЕ 

( хсі -- -Гіад ) 

■Гіад - Ггие, если и только если хсі - равно нулю. 

8.6.1.1090 02* "сМил/о-зІаг" ООЦВЦЕ 

( х сі 1 -- хсІ2 ) 
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хсІ2 - результат смещения хсіі на один бит к старшему двоичному 
разряду, заполнение освобожденного младшего бита нулем. 

8.6.1.1100 02/ "сІ-Цмо-зІазГі" ООЦВЦЕ 

( хсіі -- хсІ2 ) 

хсІ2 - результат смещения хсіі на один бит к младшему двоичному 
разряду, оставляет старший бит неизменным. 

8 . 6 . 1.1110 0 < 

( сіі сІ2 -- Гіад ) 


сІ-Іезз-ГГіап 


ООЦВЦЕ 



Лад - Ігие, если и только если сіі - меньше чем 62. 

8.6.1.1120 0= "сі-едиаіз" 001ІВІ.Е 

( хсіі хсІ2 -- -Лад ) 

Лад - Ігие, если и только если хсіі - побитно равно хсІ2. 

8.6.1.1140 Р>5 " СІ - ІО - 5" 001ІВІ.Е 

( СІ -- п ) 

п - эквивалент сІ. Неопределенная ситуация существует, если сІ 
находится вне диапазона знакового числа одна-ячейка. 

8.6.1.1160 0АВ5 "сІ-аЬз" 001ІВІ.Е 

( сІ - - исі ) 

исі - абсолютное значение сІ. 

8.6.1.1210 ОМАХ "сі-шах" 001ІВІ_Е 

( сіі сІ2 -- сІЗ ) 
сІЗ большее из сП и сІ2. 

8.6.1.1220 ОМІИ "сі-шіп" 001ІВІ_Е 

( сіі СІ2 -- сІЗ ) 
сІЗ меньшее из сіі и сІ2. 

8.6.1.1230 0ІМЕ6АТЕ "сі-педаіе" 001ІВІ.Е 

( сіі -- сІ2 ) 

62 - отрицание сіі. 

8.6.1.1820 М*/ "ш-зіаг-зіазіі" 001ІВІ_Е 

( сіі п1 +п2 -- сІ2 ) 

Умножает сіі на пі, производя промежуточный результат тройную-ячейку 
I. Делит 1: на +п2 возвращая частное сІ2 две-ячейки. Неопределенная 
ситуация существует, если +п2 нулевое или отрицательное, или 
частное находится вне диапазона целого числа со знаком двойной 
точности. 

8.6.1.1830 М+ "т-ріиз" 001ІВ1_Е 

( сіі | исіі п -- сІ2 | исІ2 ) 

Прибавляет п к сІ1|исІ1, возвращая сумму сІ2|исІ2. 

8.6.2 _ 

Расширения слов двойных чисел 
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8.6.2.0420 2Р0Т "Імо-гоіе" 001ІВ1.Е ЕХТ 

( хі х2 хЗ х4 х5 хб -- хЗ х4 х5 хб хі х2 ) 

Вращает три верхних пары-ячеек на стеке, перенося пару-ячеек хі х2 
на вершину стека. 

8.6.2.1270 01І< "сі-и-іезз" 001ІВІ.Е ЕХТ 

( и сіі исІ2 -- Тіад ) 

Лад - Ігие, если и только если исіі - меньше чем исІ2. 
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9. _ 

Дополнительный набор слов исключений 

9.1 _ 

Введение 


9.2 



Дополнительные термины и нотации 


Нет . 

9.3 _ 

Дополнительные условия применения 

9.3.1 _ 

Значения ТИРОМ 

Значения ТИРОМ {-255...-1} должны использоваться только как определено этим 
Стандартом. Значения {-4095...-256} должны использоваться только как определено 
системой. 

Если наборы слов доступа к файлу или распределения памяти реализованы, 
рекомендуется чтобы ненулевые значения іог, располагались в пределах системного 
диапазона значений ТИРОМ, как определено выше. В среде операционной системы, 
это может иногда выполняться "смещением" диапазона кодов-исключений 
операционной системы, чтобы попасть в пределы диапазона ТИРОМ. 

Программы не должны определять значения для использования с ТИРОМ в диапазоне 
{-4095...-1}. 


9.3.2 _ 

Структура исключения 

Структура исключения - зависящий-от-реализаци набор информационных записей 
текущего состояния выполнения необходимый для надлежащего функционирования 
САТСИ и ТИРОМ. Она часто включает глубину стека данных и стека возвратов. 

9.3.3 _ 

Стек исключения 

Стек, используемый САТСН и ТИРОМ для вложенных структур исключений. Он может, 
но не обязательно, быть реализован с использованием стека возвратов. 

9.3.4 _ 

Запросы к окружению 

Добавьте таблицу 9.1 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 9.1 - Строки запросов к окружению 

Строка Тип Константа Значение 


ЕХСЕРТІОИ "Лад по набор слов исключений присутствует 

ЕХСЕРТІОІМ-ЕХТ "Лад по дополнительный набор слов исключений 

присутствует 


9.3.5 _ 

Возможное действие на неопределенную ситуацию 


84 


Код 

Зарезервирован для 

Код 

Зарезервирован для 

-1 

АВОРТ 

-2 

АВОРТ" 

-3 

переполнение стека 

-4 

антипереполнение стека 

-5 

переполнение стека возвратов 

-6 

антипереполнение стека возвратов 


-7 сіо-іоорз вложен слишком глубоко в течение выполнения 





-9 

-11 

-13 

-15 

-17 

-19 

-21 


-23 

-25 

-27 

-29 

-31 


-33 

-35 

-37 

-39 

-41 

-43 

-45 

-47 

-49 

-51 

-53 

-55 

-57 


-8 переполнение словаря 

неверный адрес памяти -10 деление на нуль 

результат вне диапазона -12 несоответствие типа параметра 

неопределенное слово -14 интерпретация слова только для 

компиляции 

неверный Р0Р6ЕТ -16 попытка использовать строку 

нулевой длины как пате 

переполнение выходной строки отображаемого числа 

-18 переполнение анализируемой строки 
определение пате слишком длинное 

-20 запись в место только для чтения 
неподдерживаемая операция (например, АТ-ХУ на слишком-примитивном 
терминале) 

-22 несоответствие управляющей структуры 

исключение выравнивания адреса 

-24 неверный числовой параметр 
несогласованность стека возвратов 

-26 недоступные параметры цикла 
неверная рекурсия -28 пользовательское прерывание 

вложенность компилятора -30 устаревшая функция 

>ВОРУ используется не в СРЕАТЕ определении 

-32 неверный параметр пате (например, 

ТО ххх) 

исключение блочного чтения -34 исключение блочной записи 

неверный номер блока -36 неверная позиция файла 

исключение ввода-вывода файла -38 несуществующий файл 

неожиданный конец файла -40 неверная ВАЗЕ для преобразования 

с плавающей запятой 

потеря точности -42 деление на ноль с плавающей точкой 

результат с плавающей точкой вне диапазона 

-44 переполнение стека с плавающей точкой 
антипереполнение стека с плавающей точкой 

-46 неверный параметр с плавающей точкой 
удаленный список слов компиляции 

-48 неверный Р03ТР0МЕ 

переполнение порядка поиска -50 антипереполнение порядка поиска 
измененный список слов компиляции 

-52 переполнение стека потока управления 
исключение переполнения стека -54 антипереполнение с плавающей точкой 
неопознанная ошибка с плавающей точкой 

-56 фІЯТ 

исключение при посылке или получении символа 

-58 исключение [ІР], [ЕІ_5Е] , или [ТНЕІМ] 


9.3.6 _ 

Обработка исключений 
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Есть несколько методов применения САТСН и ТИРОМ для использования в других 
процедурах. Обычные использования - выполнение определений, использование стека 
возвратов, использование циклов, реализация Іосаіз и использование входных 
источников (то есть, с ЮАР, ЕѴАШАТЕ, или ІІМСШОЕ-РШЕ) . 

Когда ТИРОМ возвращает управление на САТСН, система должна удалить не только 
определения, но также и, если присутствует, Іосаіз и спецификации входного 
источника, чтобы возвратить систему к ее надлежащему состоянию для дальнейшего 
выполнения после САТСН. 

9.4 _ 

Дополнительные документационные требования 



9.4.1 


Системная документация 


9.4.1.1 _ 

Опции определенные реализацией 

- Значения, используемые в системе 9.6.1.0875 САТСН и 9.6.1.2275 ТИРОМ 
(9.3.1 Значения ТИРОМ, 9.3.5 Возможное действие на неопределенную ситуацию). 

9.4.1.2 _ 

Неопределенные ситуации 

- нет дополнительных требований. 

9.4.1.3 _ 

Другая системная документация 

- нет дополнительных требований. 

9.4.2 _ 

Программная документация 

- нет дополнительных требований. 

9.5 _ 

Соглашение и наименование 

9.5.1 _ 

А№ РогІИ системы 

Фраза "Предоставляет набор слов исключений" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов 
исключений. 

Фраза "Предоставляет имена из расширения набора слов исключений" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет часть 
расширения набора слов исключений. 

Фраза "Предоставляет расширение набора слов исключений" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов 
исключений и расширение набора слов исключений. 

9.5.2 _ 

А№ РогІП программы 

Фраза "Требуется набор слов исключений" должна быть добавлена к наименованию 
Стандартной программы, которая требует, чтобы система предоставила набор слов 
исключений. 


86 


Фраза "Требуются имена из расширения набора слов исключений" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения набора слов исключений. 

Фраза "Требуется расширение набора слов исключений" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь набор слов исключений и расширение набора слов исключений. 

9.6 _ 

Словарь 


9.6.1 



Слова Исключений 


9.6.1.0875 САТСН ЕХСЕРТІОИ 

( і*х хі -- }*х 0 | і*х п ) 

Помещает структуру исключения на стек исключений, и затем 
выполняется идентификатор исполнения хі (как с ЕХЕСІІТЕ) таким 
способом, что управление может быть передано в точку сразу после 
САТСН, если ТИПОМ выполнено в течение выполнения хі . 

Если выполнение хі завершается нормально (то есть, структура 
исключения помещенная этим САТСН не изъята выполнением ТИПОМ) 
изымает структуру исключения и возвращает ноль на вершине стека 
данных, выше тех элементов стека которые были бы возвращены хі 
ЕХЕСІІТЕ. Иначе, остаток семантики выполнения определяется ТИПОМ. 

9.6.1.2275 ТИПОМ ЕХСЕРТІОИ 

( к*х п -- к*х | І*х п ) 

Если какие либо биты п ненулевые, выталкивает самую верхнюю 
структуру исключения со стека исключений, вместе со всем содержимым 
стека возвратов выше этой структуры. Затем восстанавливает 
спецификацию входного источника в состояние перед соответствующим 
САТСН и корректирует состояния всех стеков, определенных этим 
Стандартом так, чтобы они были те же самые как состояния, 
сохраненные в структуре исключения (і - то же самое число, что и і 
во входных параметрах для соответствующего САТСН), помещает п на 
вершину стека данных, и передает управление на точку сразу после 
САТСН, которое поместило эту структуру исключения. 

Если вершина стека - не нулевая и нет никакой структуры исключения 
на стеке исключения, поведение следующие: 

Если п - минус-один (-1), исполняет функцию 6.1.0670 АВОПТ (версия 
АВОПТ из основного набора слов), не отображая сообщение. 

Если п - минус-два, исполняет функцию 6.1.0680 АВОПТ" (версия 
АВОПТ" из основного набора слов), отображая символы ссс связанные с 
АВОПТ" которое генерировало ТИПОМ. 

Иначе, система может отображать зависящее-от-реализации сообщение, 
возвращающее информацию о состоянии связанном с кодом ТИПОМ п. 
Впоследствии система должна выполнить функцию 6.1.0670 АВОПТ 
(версия АВОПТ из основного набора слов). 
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9.6.2 _ 

Расширения слов исключений 

9.6.2.0670 АВОПТ ЕХСЕРТІОІЧ ЕХТ 

Расширьте семантику 6.1.0670 АВОПТ, таким образом: 

( і *х -- ) ( П: ^*х -- ) 

Выполняет функцию -1 ТИПОМ. 

См.: 6.1.0670 АВОПТ. 

9.6.2.0680 АВОПТ" "аЬогІ-циоІе" ЕХСЕРТІОІЧ ЕХТ 

Расширьте семантику 6.1.0680 АВОПТ" таким образом: 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "ссс<цію1е>" -- ) 

Выделяет ссс, ограниченную " (двойная кавычка). Добавляет семантику 
времени-выполнения данную ниже к текущему определению. 



Время-выполнения: ( і*х хі -- | і*х ) ( Р: д*х -- | д*х ) 

Удаляет хі из стека. Если любой бит хі - не нулевой, выполняет 
функцию -2 ТИРОМ, отображая ссс, если нет никакой структуры 
исключения на стеке исключения. 

См.: 3.4.1 Синтаксический анализ, 6.1.0680 АВОРТ". 
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10 . _ 

Дополнительный сервисный набор слов 

10.1 _ 

Введение 

10.2 _ 

Дополнительные термины и нотации 

Нет. 

10.3 _ 

Дополнительные условия применения 

10.3.1 _ 

Символьные типы 

Программы, которые используют больше чем семь бит символа 10.6.2.1305 ЕКЕУ 
имеют зависимость от окружения. 

См.: 3.1.2 Символьные типы. 


Таблица 10.1 - Строки запросов к окружению 

Строка Тип Константа Значение 


РАСІІЛТѴ "Лад по сервисный набор слов присутствует 

РАСІІЛТѴ-ЕХТ "Лад по дополнительный сервисный набор слов 

присутствует 


10.4 _ 

Дополнительные документационные требования 

10.4.1 _ 

Системная документация 

10.4.1.1 _ 

Опции определенные реализацией 

- кодирование событий клавиатуры (10.6.2.1305 ЕКЕУ); 

- длительность такта системных часов; 

- повторяемость ожидаемая от выполнения 10.6.2.1905 М5. 

10.4.1.2 _ 

Неопределенные ситуации 

- 10.6.1.0742 АТ-ХУ операция не может быть выполнена на пользовательском 
устройстве вывода. 


10.4.1.3 





Другая системная документация 


- нет дополнительных требований. 
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10.4.2 _ 

Программная документация 

10.4.2.1 _ 

Зависимости от окружения 

- Использование больше чем семь битов символа в 10.6.2.1305 ЕКЕУ. 

10.4.2.2 _ 

Другая программная документация 

- нет дополнительных требований. 

10.5 _ 

Соглашение и наименование 


10.5.1 _ 

А№ РогІИ системы 

Фраза "Предоставляет сервисный набор слов" должна быть добавлена к наименованию 
любой Стандартной системы, которая предоставляет весь сервисный набор слов. 

Фраза "Предоставляет имена из расширения сервисного набора слов" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет часть 
расширения сервисного набора слов. 

Фраза "Предоставляет расширение сервисного набора слов" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь сервисный 
набор слов и расширение сервисного набора слов. 


10.5.2 _ 

А№ РогІП программы 

Фраза "Требуется сервисный набор слов" должна быть добавлена к наименованию 
Стандартной программы, которая требует, чтобы система предоставила сервисный 
набор слов. 

Фраза "Требуются имена из расширения сервисного набора слов" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения сервисного набора слов. 

Фраза "Требуется расширение сервисного набора слов" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь сервисный набор слов и расширение сервисного набора слов. 


10.6 _ 

Словарь 


10 . 6.1 _ 

Сервисные слова 

10.6.1.0742 АТ-ХУ "аі-х-у" РАСШТУ 

( иі и2 -- ) 

Исполняет зависящие-от-реализации шаги так, чтобы следующий 
отображаемый символ появился в столбце иі, строке и2 
пользовательского устройства вывода, верхний левый угол которого - 
нулевой столбец и нулевая строка. Неопределенная ситуация 



существует, если операция не может быть выполнена на 
пользовательском устройстве вывода с определенными параметрами. 
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10.6.1.1755 КЕУ? "кеу-циезііоп" РАСПНУ 

( -- -Лад ) 

Если символ доступен, возвращает Ігие. Иначе, возвращает 63156. 

Если не символьные события клавиатуры доступны перед первым 
допустимым символом, они будут отвергнуты и впоследствии 
недоступны. Символ должен быть возвращен следующим выполнением КЕУ. 

После возвращения КЕУ? со значением Ігие, последующие выполнения 
КЕУ? до выполнения КЕУ или ЕКЕУ также возвращают Ігие, без отмены 
событий клавиатуры. 

10.6.1.2005 РАСЕ РАСПНУ 

( -- ) 

Перемещение на другую страницу для вывода. Фактическая функция 
зависит от устройства вывода. На терминале, РАСЕ очищает экран и 
сбрасывает позицию курсора к верхнему левому углу. На принтере, 

РАСЕ исполняет прогон страницы. 

10 . 6.2 _ 

Расширения сервисных слов 

10.6.2.1305 ЕКЕУ "е-кеу" РАСПНУ ЕХТ 

( -- и ) 

Получает одно событие клавиатуры и. Кодирование событий клавиатуры 
определенное реализацией. 

См.: 10.6.1.1755 КЕУ?, 6.1.1750 КЕУ. 


10.6.2.1306 ЕКЕУ>СНАР "е-кеу-іо-сбаг" РАСПНУ ЕХТ 

( и -- и баізе | сбаг Ігие ) 

Если событие клавиатуры и соответствует символу в наборе символов 
определенном реализацией, возвращает этот символ и Іше. Иначе 
возвращает и и баізе . 

10.6.2.1307 ЕКЕУ? "е-кеу-циезіііоп" РАСПНУ ЕХТ 

( -- -Лад ) 

Если событие клавиатуры доступно, возвращает Ігие. Иначе возвращает 
баізе . Событие должно быть возвращено следующим выполнением ЕКЕУ. 

После возвращения ЕКЕУ? со значением Ігие, последующее выполнение 
ЕКЕУ? до выполнения КЕУ, КЕУ? или ЕКЕУ также возвращает Іше, 
ссылаясь на то же самое событие. 


10.6.2.1325 ЕМІТ? "етП-диезИоп" РАСПНУ ЕХТ 

( -- -Лад ) 

біад - Ігие, если пользовательское устройство вывода готово принять 
данные и выполнение ЕМІТ на месте ЕМІТ? не испытывало бы 
неопределенной задержки. Если состояние устройства не определено, 
біад - Ігие (? баізе) . 

10.6.2.1905 М5 РАСПНУ ЕХТ 

( и -- ) 

Ожидание, по крайней мере, и миллисекунд. 


91 


Примечание: Фактическая длина и изменчивость периода времени зависят 



от определенной реализацией разрешающей способности системных часов 
и других системных и компьютерных характеристик, и находится вне 
контекста этого Стандарта. 

10.6.2.2292 ТІМЕ&ОАТЕ "Ііше-апсі-сіаііе" РАСПНУ ЕХТ 

( -- +ПІ +п2 +пЗ +п4 +п5 +п6 ) 

Возвращает текущее время и дату. +п1 - секунды {Ѳ...59}, +п2 минуты 
{Ѳ...59}, +пЗ - часы {0...23}, +п4 - день {1...31} +п5 - месяц 
{1...12}, и +п6 - год (например, 1991). 
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11 . _ 

Дополнительный набор слов доступа к файлам 

11.1 _ 

Введение 

Эти слова предоставляют доступ к запоминающему устройству в форме "файлов" при 
следующих допущениях: 

- файлы предусмотрены базовой операционной системой; 

- имена файлов представлены как символьные строки; 

- формат имен файла определен базовой операционной системой; 

- открытый файл идентифицирован идентификатором файла одна-ячейка (Тііеісі); 

- информация состояния файла (например, позиция, размер) управляется базовой 
операционной системой; 

- к содержанию файла обращаются как к последовательности символов; 

- операции чтения файла возвращают фактический размер передачи, который может 
отличиться от требуемого размера передачи. 

11.2 _ 

Дополнительные термины 

метод доступа к файлу: допустимые средства доступа к файлу, типа "чтения - 
записи" или "только для чтения". 

позиция файла: смещение символа от начала файла. 

входной файл: файл, содержащий последовательность строк, которая является 
входным источником. 

11.3 _ 

Дополнительные условия применения 

11.3.1 _ 

Типы данных 

Добавьте таблицу 11.1 к таблице 3.1. 


Таблица 11.1 - Типы данных 

Символ Тип данных Размер на стеке 


іог результат ввода-вывода 1 ячейка 
Таш метод доступа к файлу 1 ячейка 
Тііеісі идентификатора файла 1 ячейка 


11.3.1.1 


Идентификаторы файла 





Идентификаторы файла - это зависящие-от-реализации значения одна-ячейка, 
которые передаются к файловым операторам для обозначения конкретных файлов. 
Открытие файла назначает идентификатор файла, который остается действительным 
до закрытия файла. 

11.3.1.2 _ 

Результаты ввода-вывода 

Результат ввода-вывода - это числа одна-ячейка, указывающие результат операций 
ввода-вывода. Значение нуль указывает, что операция ввода-вывода завершилась 
успешно; другие значения и их смысл - определенное реализацией. Достижение 
конца файла должно быть сообщено как нуль. 
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Исключение ввода-вывода при выполнении слова доступа к файлу, которое может 
возвращать результат ввода-вывода не должно вызывать ТНРО\л/; индикация 
исключений возвращается в іог. 

11.3.1.3 _ 

Методы доступа к файлу 

Методы доступа к файлу - это значение одна-ячейка определенное реализацией. 

11.3.1.4 _ 

Имена файла 

Символьная строка, содержащая имя файла. Имя файла может включать зависящий-от- 
реализации путь имени. Формат имен файла - определенное реализацией. 

11.3.2 _ 

Блоки в файлах 

Если набор слов доступа к файлу реализован, блочный набор слов должен быть 
реализован. 

Блоки могут находиться в файлах, но не обязательно. Тогда: 

- Номера блоков могут быть отображены на один или более файлов средствами 
определенными реализацией. Неопределенная ситуация существует, если требуемый 
номер блока в настоящее время не отображен; 

- Блок, для которого выполнен ІІРРАТЕ, и который получен из файла, должен быть 
возвращен назад в тот же самый файл. 

11.3.3 _ 

Запросы к окружению 

Добавьте таблицу 11.2 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 11.2 - Строки запросов к окружению 

Строка Тип Константа Значение 

РІІ_Е "Лад по файловый набор слов представлен 

РШЕ-ЕХТ "Лад по расширение файлового набора слов представлено 


11.3.4 


Входной источник 





Набор слов доступа к файлу создает другой входной источник для текстового 
интерпретатора. Когда входной источник - текстовый файл, ВІ_К должен содержать 
нуль, ЗОІІНСЕ-Ю должен содержать бііеісі этого текстового файла, и входной буфер 
должны содержать одну строку текстового файла. 

Ввод с ІІМСШОЕО, ІІ\ІСІ_ІЮЕ-РІІ_Е, 1_0А0 и ЕѴАШАТЕ, должен иметь возможность 
вложения в любом порядке по крайней мере до восьми уровней. 

Программа, которая использует больше чем восемь уровней вложения входного 
файла, имеет зависимость от окружения. 

См.: 3.3.3.5 Входные буферы, 9. Дополнительный набор слов исключений. 
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11.3.5 _ 

Другие временные области 

Список слов использующих память во временных областях расширен, для включения 
11.6.1.2165 5". 

См.: 3.3.3.6 Другие временные области. 

11.3.6 _ 

Синтаксический анализ 

При синтаксическом анализе из текстового файла, использующего разделитель 
пробел, управляющие символы должны быть обработаны так же как пробел. 

Должны поддерживаться строки, по крайней мере, 128 символов. Программа, которая 
требует строки больше чем 128 символов, имеет зависимость от окружения. 

Программа может переустанавливать область анализа в пределах входного буфера, 
управляя содержанием >ІІ\І. Более обширное переустановление может быть выполнено, 
с использованием 5АѴЕ-ІМРІІТ и РЕ5Т0РЕ- ІМРІІТ . 

См.: 3.4.1 Синтаксический анализ. 

11.4 _ 

Дополнительные документационные требования 

11.4.1 _ 

Системная документация 

11.4.1.1 _ 

Опции определенные реализацией 

- методы доступа к файлу, используемые в 11.6.1.Ѳ765 ВІІМ, 

11.6.1.1Ѳ1Ѳ СРЕАТЕ-РІІ.Е, 11.6.1.1970 ОРЕМ-РІБЕ, 11.6.1.2054 Р/0, 

11.6.1.2056 НА/, апсі 11.6.1.2425 ѴУ/0 ; 

- файловые исключения; 

- признак конца строки файла (11.6.1.2090 РЕАО-ІЛМЕ); 

- формат имени файла (11.3.1.4 Имена файла); 

- информация, возвращаемая 11.6.2.1524 РІІ_Е-5ТАТІІЗ; 

- состояние входного файла после исключения (11.6.1.1717 ІІ\ІСІ_ІІ0Е-РІІ_Е, 
11.6.1.1718 ІМСШОЕО); 

- іог значения и смысл (11.3.1.2 Результаты ввода-вывода); 

- максимальная глубина вложенности файлового ввода (11.3.4 Входной источник); 

- максимальный размер входной строки (11.3.6 Синтаксический анализ); 

- методы отображения диапазона блоков на файлы (11.3.2 Блоки в файлах); 

- предусмотренное число строковых буферов (11.6.1.2165 3"); 

- размер строкового буфера, используемого в 11.6.1.2165 5". 



11.4.1.2 


Неопределенные ситуации 

- попытка позиционировать файл вне его границ (11.6.1.2142 РЕР05ІТІ0І\І-РІІ_Е) ; 

- попытка читать из еще не записанной позиции файла (11.6.1.2Ѳ8Ѳ РЕАЦ-РШЕ, 

11.6.1.2090 КЕАб-ИМЕ); 

- Тііеісі неверен (11.6.1.1717 ІІ\ІСІ.ІЮЕ-РІІ_Е) ; 

- исключение ввода-вывода чтения или закрытия Тііеісі (11.6.1.1717 ІІ\ІСШОЕ-РІІ_Е, 
11.6.1.1718 ІМСІ-ІЮЕО) ; 
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- указанный файл не может быть открыт (11.6.1.1718 ІІ\ІСІ_ІЮЕО); 

- требование не существующего номера блока (11.3.2 Блоки в файлах); 

- использование 11.6.1.2218 501ІПСЕ-Ю, когда 7.6.1.0790 В1_К - не нулевой. 

11.4.1.3 _ 

Другая системная документация 

- нет дополнительных требований. 

11.4.2 _ 

Программная документация 

11.4.2.1 _ 

Зависимости от окружения 

- требование строки больше 128 символов (11.3.6 Синтаксический анализ); 

- использование больше чем восемь уровней вложения входного файла (11.3.4 
Входной источник). 

11.4.2.2 _ 

Другая программная документация 

- нет дополнительных требований. 

11.5 _ 

Соглашение и наименование 

11.5.1 _ 

АІ\І5 РогТб системы 

Фраза "Предоставляет набор слов доступа к файлу" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов 
доступа к файлу. 

Фраза "Предоставляет имена из расширения набора слов доступа к файлу" должна 
быть добавлена к наименованию любой Стандартной системы, которая предоставляет 
часть расширения набора слов доступа к файлу. 

Фраза "Предоставляет расширение набора слов доступа к файлу" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет весь 
набор слов доступа к файлу и расширение набора слов доступа к файлу. 

11.5.2 _ 

АІМ5 РогТб программы 

Фраза "Требуется набор слов доступа к файлу" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
набор слов доступа к файлу. 


Фраза "Требуются имена из расширения набора слов доступа к файлу" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 



предоставила часть расширения набора слов доступа к файлу. 

Фраза "Требуется расширение набора слов доступа к файлу" должна быть добавлена 
к наименованию Стандартной программы, которая требует, чтобы система 
предоставила весь набор слов доступа к файлу и расширение набора слов доступа к 
файлу. 

11.6 _ 

Словарь 

11 . 6.1 _ 

Слова доступа к файлу 
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11.6.1.ѲѲ80 ( "рагеп" РІІ.Е 

( "ссс<рагеп>" -- ) 

Расширьте семантику 6.1.0080 ( включив: 

При синтаксическом анализе из текстового файла, если конец области 
анализа достигнут прежде, чем найдена правая круглая скобка, снова 
наполняет входной буфер из следующей строки файла, обнуляет >ІІ\І, и 
возобновляет синтаксический анализ, повторяет этот процесс до 
нахождения правой круглой скобки или достижения конца файла. 

11.6.1.0765 ВІМ РІІ_Е 

( баті -- бат2 ) 

Изменяет метод доступа к файлу определенный реализацией баті, 
дополнительно выбирая "Ьіпагу", то есть не строко-ориентированный 
метод доступа к файлу, возвращая метод доступа бат2. 

См.: 11.6.1.2054 Р/0, 11.6.1.2056 РА/, 11.6.1.2425 \л//0. 

11.6.1.0900 СІ_05Е-РІІ_Е РІІ_Е 

( бііеіб -- іог ) 

Закрывает файл, идентифицированный 611616. іог - определенный 
реализацией код результата ввода-вывода. 

11.6.1.1010 СРЕАТЕ-РІЦЕ РІІ_Е 

( с-абсіг и баш -- бііеіб іог ) 

Создает файл именованный символьной строкой, определенной с-асісіг и 
и, и открывает его с методом доступа к файлу баш. Смысл значений 
баш является определенным реализацией. Если файл с тем же самым 
именем уже существует, пересоздает его как пустой файл. 

Если файл был успешно создан и открыт, іог нулевой, бііеіб его 
идентификатор, и файл был позиционирован в начало. 

Иначе, іог - код результата ввода-вывода определенный реализацией и 
бііеіб неопределенное. 

11.6.1.1190 ОЕІ_ЕТЕ-РІІ_Е РІІ_Е 

( с-асісіг и -- іог ) 

Удаляет файл, именованный символьной строкой, определенной с-абсіг 
и. іог - определенный реализацией код результата ввода-вывода. 

11.6.1.1520 РІІ.Е-Р05ІТІ0М РІІ_Е 

( бііеіб -- исі іог ) 

иб - текущая позиция для файла идентифицированного бііеіб. іог 
является кодом результата ввода-вывода определенным реализацией, исі 
не определен если іог является ненулевым. 


11.6.1.1522 РІ6Е-5І2Е 


РІІ_Е 



( іііеісі -- исі іог ) 
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исі - размер в символах файла, идентифицированного іііеісі. іог 
является кодом результата ввода-вывода определенным реализацией. 

Эта операция не затрагивает значение, возвращаемое РІІ_Е-Р05ІТІ0І\І . 
исі не определен, если іог ненулевой. 

11.6.1.1717 ІІ\ІСІ_ІЮЕ-РІІ_Е РНЕ 

( і*х іііеісі -- }*х ) 

Удаляет іііеісі со стека. Сохраняет спецификацию текущего входного 
источника, включая текущее значение 501ІРСЕ-Ю. Запоминает іііеісі в 
501ІРСЕ-Ю. Делает файл определенный іііеісі входным источником. 
Записывает нуль в ВІ_К. Другое состояние стека по причине 
обработанных слов. 

Повторяет до конца файла: читает строку из файла, заполняет входной 
буфер содержимым этой строки, обнуляет >ІІ\І, и интерпретирует. 

Текстовая интерпретация начинается в позиции файла, где произошло 
бы следующее чтение файла. 

Когда достигнут конец файла, закрывает файл и восстанавливает 
спецификацию входного источника к ее сохраненному значению. 

Неопределенная ситуация существует, если іііеісі неверен, если есть 
исключение ввода-вывода чтения іііеісі, или если исключение ввода- 
вывода происходит при закрытии іііеісі. Когда неопределенная 
ситуация существует, состояние (открытый или закрытый) для любых 
файлов которые интерпретировались - определенное реализацией. 

См.: 11.3.4 Входной источник. 

11.6.1.1718 :ШС1_1ЮЕ0 РНЕ 

( і*х с-асісіг и -- }*х ) 

Удаляет с-асісіг и со стека. Сохраняет спецификацию текущего входного 
источника, включая текущее значение 501ІПСЕ-Ю. Открывает файл 
определенный с-асісіг и, сохраняет результирующий іііеісі в 501ІКСЕ-Ю, 
и делает его входным источником. Сохраняет нуль в В1_К. Другое 
состояние стека по причине включенных слов. 

Повторяет до конца файла: читает строку из файла, заполняет входной 
буфер содержимым этой строки, обнуляет >ІІ\І, и интерпретирует. 

Текстовая интерпретация начинается в позиции файла, где произошло 
бы следующее чтение файла. 

Когда достигнут конец файла, закрывает файл и восстанавливает 
спецификацию входного источника к ее сохраненному значению. 

Неопределенная ситуация существует, если заданный файл не может 
быть открыт, если исключение ввода-вывода происходит при чтении 
файла, или если исключение ввода-вывода происходит при закрытии 
файла. Когда неопределенная ситуация существует, состояние 
(открытый или закрытый) любых файлов которые интерпретировались - 
определенное реализацией. 

См.: 11.6.1.1717 ІИСШОЕ-РНЕ. 
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11.6.1.1970 


РШЕ 


ОРЕІМ-РШЕ 

( с-асісіг и іаш -- іііеісі іог ) 

Открывает файл заданный символьной строкой определенной с-асісіг и, с 
методом доступа к файлу, обозначенным іаш. Смысл значений іат 
определенный реализацией. 

Если файл успешно открыт, іог нулевой, іаш - его идентификатор, и 
файл был позиционирован начало. 

Иначе, іог - код результата ввода-вывода определенный реализацией и 
іаш неопределенное. 

11.6.1.2054 Р/0 "г-о" РШЕ 

( - - іаш ) 

іаш - значение определенное реализацией для выбора метода доступа к 
файлу "только для чтения". 

См.: 11.6.1.1Ѳ1Ѳ СПЕАТЕ-РШЕ, 11.6.1.1970 ОРЕІ\І-РШЕ. 

11.6.1.2056 Р/М "г-м" РШЕ 

( - - іаш ) 

іаш - значение определенное реализацией для выбора метода доступа к 
файлу "чтение - запись". 

См.: 11.6.1.1010 СРЕАТЕ-РШЕ, 11.6.1.1970 ОРЕІ\І-РШЕ. 

11.6.1.2080 РЕАР-РШЕ РШЕ 

( с-асісіг иі іііеісі -- и2 іог ) 

Читает иі последовательных символов в с-асісіг с текущей позиции 
файла, идентифицированного іііеісі. 

Если иі символы читаются без исключения, іог нулевое, и и2 равно 
иі. 

Если конец файла достигнут, прежде прочтения иі символов, іог нуль 
и и2 - число фактически прочитанных символов. 

Если операция инициализирована когда значение, возвращенное РШЕ- 
Р05ІТІ0М равно значению, возвращенному РШЕ-5І2Е для файла 
идентифицированного іііеісі - іог нулевое, и и2 нулевое. 

Если происходит исключение, іог - код результата ввода-вывода 
определенный реализацией, и и2 - число символов переданное в с- 
асісіг без исключения. 

Неопределенная ситуация существует, если операция инициализирована 
когда значение, возвращенное РШЕ-Р05ІТІ0ІМ большее чем значение, 
возвращенное РШЕ-5І2Е для файла, идентифицированного іііеісі, или 
если требуемая операция пытается читать не записанные части файла. 
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При завершении операции, РШЕ-Р05ІТІ0ІМ возвращает следующую позицию 
файла после последнего прочтенного символа. 

11.6.1.2090 ПЕАО- І_ІІ\ІЕ РШЕ 

( с-асісіг иі іііеісі -- и2 ііад іог ) 

Читает следующую строку из файла, определенного іііеісі в память с 
адреса с-асісіг. Читаются максимум иі символов. До двух символов 
завершения строки определенных реализацией могут читаться в память 
в конец строки, но не включаются в количество и2. Буфер строки, 
предусмотренный с-асісіг должен быть, по крайней мере, длиной и1+2 
символов. 



Если операция успешная, біад - ігие, и іог нулевой. Если признак 
конца строки был получен прежде прочтения символов иі, тогда 
фактически читается и2-число символов, не включая признак конца 
строки(Ѳ <= и2 <= иі) . Когда иі = и2, признак конца строки должен 
все же быть достигнут. 

Если операция инициализирована когда значение, возвращенное РІІ_Е- 
Р05ІТІ0М равно значению, возвращенному РШЕ-5І2Е для файла, 
идентифицированного бііеісі, біад - баізе, іог нулевое, и и2 
нулевое. Если іог ненулевое, в течение операции произошло 
исключение, и іог - определенный реализацией код завершения ввода- 
вывода . 

Неопределенная ситуация существует, если операция инициализирована 
когда значение, возвращенное РІІ_Е-Р05ІТІ0І\І больше чем значение, 
возвращенное РШЕ-5І2Е для файла, идентифицированного бііеісі, или 
если требуемая операция пытается читать не записанные части файла. 

При завершении операции, РІІ_Е-Р05ІТІ0І\І возвращает следующую позицию 
файла после последнего прочтенного символа. 

11.6.1.2142 РЕР05ІТІ0ІМ - РНЕ РНЕ 

( исі бііеісі -- іог ) 

Переустанавливает позицию файла, идентифицированного бііеісі на исі. 
іог - код завершения ввода-вывода определенный реализацией. 
Неопределенная ситуация существует если файл позиционирован вне 
границ файла. 

При завершении операции, РІІ_Е-Р05ІТІ0І\І возвращает значение исі. 

11.6.1.2147 РЕ5І2Е-РНЕ РНЕ 

( исі бііеісі -- іог ) 

Устанавливает размер файла, идентифицированного бііеісі на исі. іог - 
код завершения ввода-вывода определенный реализацией. 

Если результирующий файл больше чем файл перед операцией, часть 
файла добавленного в результате операции могла бы быть не записана. 

При завершении операции, РШЕ-5І2Е возвращает значение исі и РІІ_Е- 
РОЗПІСЖ возвращает неопределенное значение. 
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См.: 11.6.1. 2Ѳ8Ѳ РЕАР-РШЕ, 11.6.1.2090 КЕАО-ІЛІЧЕ. 

11.6.1.2165 5" "з-диоіе" РШЕ 

Расширьте семантику 6.1.2165 5" так: 

Интерпретация: ( "ссс<дио1;е>" -- с-асісіг и ) 

Выделяет ссс, ограниченную " (двойная кавычка). Сохраняет 
результирующую строку с-асісіг и во временном местоположении. 
Максимальная длина временного буфера зависящая-от-реализаци, но 
должна быть не меньше чем 80 символов. Последующие использования 5" 
могут перезаписывать временный буфер. По крайней мере, один такой 
буфер должен быть предусмотрен. 

Компиляция: ( "ссс<дио1;е>" -- ) 

Выделяет ссс, ограниченную " (двойная кавычка). Добавляет семантику 
времени-выполнения данную ниже к текущему определению. 


Время-выполнения: ( -- с-асісіг и ) 

Возвращает с-абсіг и и, которые описывают строку, состоящую из 



символов ссс. 


См.: 3.4.1 Синтаксический анализ, 6.2.Ѳ855 С", 6.1.2165 5", 11.3.5 
Другие временные области. 

11.6.1.2218 501ІКСЕ-Ю "зоигсе-і-сі" РШЕ 

( -- 0 | -1 | Тііеісі ) 

Расширьте 6.2.2218 501ІРСЕ-Ю, чтобы включить ввод текстового файла 
следующим образом: 

501ІРСЕ- Ю Входной источник 


Тііеісі Текстовый файл "Тііеісі" 

-1 Строка (через ЕѴАШАТЕ) 

Ѳ Пользовательское устройство ввода 


Неопределенная ситуация существует, если 501ІРСЕ-Ю используется, 
когда ВІ_К содержит ненулевое значение. 

11.6.1.2425 VI /0 "м-о" РШЕ 

( - - Таш ) 

баш - значение определенное реализацией для выбора метода доступа к 
файлу "только запись". 

См.: 11.6.1.1010 СРЕАТЕ-РШЕ, 11.6.1.1970 ОРЕІМ-РШЕ. 

11.6.1.2480 ШІТЕ-РШЕ РШЕ 

( с-асісіг и Тііеісі -- іог ) 

Записывает и символов из с-асісіг в файл, идентифицированный Тііеісі 
начиная с его текущей позиции, іог - определенный реализацией код 
результата ввода-вывода. 
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При завершении операции, РІІ_Е-Р05ІТІ0І\І возвращает следующую позицию 
файла после последнего символа записанного в файл, и РШЕ-5І2Е 
возвращает значение большее или равное значению возвращенному РШЕ- 
Р05ІТІ0М. 

См.: 11.6.1.2080 РЕАО-РШЕ, 11.6.1.2090 КЕАО-ІЛІМЕ. 

11.6.1.2485 МПІТЕ- І_ІІ\ІЕ РШЕ 

( с-асісіг и Тііеісі -- іог ) 

Записывает и символов из с-асісіг, сопровождаемых зависящим-от- 
реализации признаком конца строки в файл, идентифицированный Тііеісі 
начиная с его текущей позиции, іог - определенный реализацией код 
результата ввода-вывода. 

При завершении операции, РШЕ-Р05ІТІ0ІМ возвращает следующую позицию 
файла после последнего символа записанного в файл, и РШЕ-5І2Е 
возвращает значение большее или равное значению возвращенному РШЕ- 
Р05ІТІ0М. 

См.: 11.6.1.2080 КЕАР-РШЕ, 11.6.1.2090 РЕАО-ІЛІМЕ. 


11 . 6.2 _ 

Расширения слов доступа к файлу 

11.6.2.1524 РШЕ-5ТАТІІ5 РШЕ ЕХТ 

(с-асісіг и -- х іог ) 

Возвращает состояние файла, идентифицированного символьной строкой 
с-асісіг и. Если файл существует, іог нулевой; иначе іог - код 





завершения ввода-вывода определенный реализацией, х содержит 
определенную реализацией информацию о файле. 


11.6.2.1560 РШ5Н-РШЕ РНЕ ЕХТ 

( ■рііеісі -- іог ) 

Пытается инициировать запись на запоминающее устройство любую 
буферизированную информацию, записанную в файл, относящийся к 
бііеісі, и информация о размере файла будет записана в каталоге 
хранения при изменении. Если операция успешна, іог нулевой. Иначе, 
это - код завершения ввода-вывода определенный реализацией. 

11.6.2.2125 ПЕРІШ РНЕ ЕХТ 

( -- -Лад ) 

Расширьте семантику выполнения 6.2.2125 РЕРІШ следующим: 

Когда входной источник - текстовый файл, пытается читать следующую 
строку из текстового входного файла. Если успешно, делает результат 
текущим входным буфером, обнуляет >ІІ\І, и возвращает ігие. Иначе 
возвращает Таізе. 

См.: 6.2.2125 РЕРІШ, 7.6.2.2125 РЕРІШ. 

11.6.2.2130 РЕМАМЕ-РИЕ РІІ_Е ЕХТ 

( с-абсігі иі с-асІсІг2 и2 -- іог ) 
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Переименовывает файл, именованный символьной строкой с-абсігі иі в 
имя из символьной строки с-асІсІг2 и2. іог - код завершения ввода- 
вывода определенный реализацией. 
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12 . _ 

Дополнительный набор слов для плавающей точки 

12.1 _ 

Введение 

12.2 _ 

Дополнительные термины и нотация 

12 . 2.1 _ 

Определение терминов 

С-плавающей-точкой-выровненный адрес: Адрес ячейки памяти, к которой можно 
обращаться как к числу с плавающей точкой. 

Двойной-с-плавающей-точкой-выровненный адрес: Адрес ячейки памяти, к которой 
можно обращаться как к 64 бит ІЕЕЕ числу с плавающей точкой двойной точности. 

Одинарный-с-плавающей-точкой-выровненный адрес: Адрес ячейки памяти, к которой 
можно обращаться как к 32 бит ІЕЕЕ числу с плавающей точкой одинарной 
точности. 

Число с плавающей точкой ІЕЕЕ: Число с плавающей точкой одинарной или двойной 
точности, как определено в А№І/ІЕЕЕ 754-1985. 

12 . 2.2 _ 

Нотация 


12 . 2 . 2.1 



Числовая нотация 


Следующая нотация используется для определения синтаксиса внешнего 

представления числа с плавающей точкой: 

- Каждый компонент числа с плавающей точкой определен правилом, состоящим из 
имени компонента (выделенного курсивом в угловых скобках, например, <знак>), 
символов := и связанных лексем и метасимволов; 

- Лексемы могут быть литеральными символами (полужирным шрифтом, например, Е) 
или правильными именами в угловых скобках (например, <цифра>); 

- Метасимвол * используется, чтобы определить нуль или большее количество 
появлений предшествующей лексемы (например, <сІіді1:>*); 

- Лексемы заключенные в [ и ] необязательные (например, [<знак>]); 

- Вертикальные линии отделяют выборы из списка лексем заключенных в фигурные 
скобки (например{ + | - }). 

12 . 2 . 2.2 _ 

Стековая нотация 

Когда стек с плавающей точкой отделен от стека данных - стековая нотация с 

плавающей точкой такая: 

( Р: ЬеТоге -- аТіег ) 


12.3 _ 

Дополнительные условия применения 

12.3.1 _ 

Типы данных 

Добавьте таблицу 12.1 к таблице 3.1. 
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Таблица 12.1 - Типы данных 


Символ 

Тип данных 

Размер на стеке 

г 

числа с плавающей точкой 

определенное реализацией 

Т-асІсІг 

с - плавающей - точкой 
выровненный адрес 

1 ячейка 

зТ-асІсІг 

одинарный-с-плавающей-точкой 
выровненный адрес 

1 ячейка 

сІТ-асІсІг 

двойной-с-плавающей-точкой 
выровненный адрес 

1 ячейка 


12.3.1.1 _ 

Адреса 

Набор с-плавающей-точкой-выровненных адресов - подмножество определенного 
реализацией набора выровненных адресов. Добавление размера числа с плавающей 
точкой к с-плавающей-точкой-выровненному адресу должно производить с-плавающей- 
точкой-выровненный адрес. 

Набор двойных-с-плавающей-точкой-выровненных адресов - подмножество 
определенного реализацией набора выровненных адресов. Добавление размера 64-бит 
ІЕЕЕ числа с плавающей точкой двойной точности к двойному-с-плавающей-точкой- 
выровненному адресу должно произвести двойной-с-плавающей-точкой-выровненный 
адрес. 


Набор одинарных-с-плавающей-точкой-выровненных адресов - подмножество 





определенного реализацией набора выровненных адресов. Добавление размера 32-бит 
ІЕЕЕ числа с плавающей точкой одинарной точности к одинарному-с-плавающей- 
точкой-выровненному адресу должно произвести одинарный-с-плавающей-точкой- 
выровненный адрес. 

12.3.1.2 _ 

Числа с плавающей точкой 

Внутреннее представление числа с плавающей точкой включая формат и точность 
мантиссы и формат и диапазон экспоненты, является определенным реализацией. 

Любое округление или усечение чисел с плавающей точкой - определенное 
реализацией. 

12.3.2 _ 

Операции с плавающей точкой 

"Округление к ближайшему" означает округление результата операции с плавающей 
точкой к представимому значению ближайшему к результату. Если два ближайших 
представимых значения одинаково близки к результату, должен быть представлен 
тот, наименьший значащий бит которого нулевой. 

"Округление к отрицательной бесконечности" означает округление результата 
операции с плавающей точкой к представимому значению ближайшему и не большему 
чем результат. 

12.3.3 _ 

Стек с плавающей точкой 

Последний пришел, первым ушел список, который должен использоваться всеми 
операторами с плавающей точкой. 

Размер стека с плавающей точкой - определенный реализацией. По умолчанию стек 
с плавающей точкой должен быть отделен от стека данных и стека возвратов. 
Программа может определять, располагаются ли числа с плавающей точкой на стеке 
данных, посылая строку "РІ_0АТІМ6-5ТАСК" в ЕІ\ІѴІРСШМЕІ\ІТ? . 
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Размер стека с плавающей точкой должен быть, по крайней мере 6 элементов. 

Программа, которая зависит от стека с плавающей точкой, являющегося большим чем 
6 элементов, имеет зависимость от окружения. 

12.3.4 _ 

Запросы к окружению 

Добавьте таблицу 12.2 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 12.2 - Строки запросов к окружению 


Строка 

Тип 

Константа 

Значение 

РІ_0АТІМ6 

Пад 

по 

набор слов с 

плавающей 

точкой представлен 

РЮАТІМ6-ЕХТ 

Пад 

по 

расширенный 

представлен 

набор слов 

с плавающей точкой 

РІ_0АТІМ6-5ТАСК 

п 

уез 

если п = нуль, числа с 

плавающей точкой 


располагаются на стеке данных; 

иначе п - максимальная глубина отделенного 

стека с плавающей точкой 




МАХ - Р1_0АТ 


г уез самое большое пригодное для использования 
число с плавающей точкой 


12.3.5 _ 

Выравнивание адреса 

Так как адрес возвращенный словом созданным СВЕАТЕ не обязательно выровнен для 
любой части класса данных с плавающей точкой, программа должна выровнять адрес 
(чтобы он был выровненным: с плавающей точкой, одинарным-с-плавающей-точкой, 
или двойным-с-плавающей-точкой) перед доступом по адресу к данным с плавающей 
точкой. 

См.: 3.3.3.1 Выравнивание адреса, 12.3.1.1 Адреса. 

12.3.6 _ 

Переменные 

Программа может адресовать память в зонах областей данных, сделанных доступными 
с помощью РѴАВІАВІ_Е. Эти области могут быть несмежными участками с зонами 
последовательно распределенными с помощью , (запятой) или А1_І_0Т . 

См.: 3.3.3.3 Переменные. 

12.3.7 _ 

Преобразование входных чисел текстового интерпретатора 

Если набор слов с плавающей точкой присутствует в словаре, и текущее основание 
ОЕСІМАІ_, входной алгоритм преобразования чисел должен быть расширен для 
распознавания чисел с плавающей точкой в такой форме: 

Преобразуемая строка := <мантисса><экспонента> 

<мантисса> := [<знак>]<цифры>[. <цифрыѲ>] 

<экспонента> := Е[<знак>]<цифрыѲ> 

<знак> := { + | - } 

<цифры> := <цифра><цифрыѲ> 
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<цифрыѲ> := <цифра>* 

<цифра> :={Ѳ|1[2|3|4|5|6|7|8|9} 

Это - примеры допустимых представлений чисел с плавающей точкой в источнике 
программы: 

1Е 1.Е 1.ЕѲ +1.23Е-1 -1.23Е+1 

См.: 3.4.1.3 Преобразование входных чисел текстового интерпретатора, 

12.6.1.0558 >Р1_0АТ. 

12.4 _ 

Дополнительные документационные требования 

12.4.1 _ 

Системная документация 

12.4.1.1 _ 

Опции определенные реализацией 

- формат и диапазон чисел с плавающей точкой (12.3.1 Типы данных, 

12.6.1.2143 КЕРКЕЗЕІЧТ); 

- результат 12.6.1.2143 КЕРВЕ5ЕІМТ, когда число с плавающей точкой находится вне 
диапазона; 




- округление или усечение чисел с плавающей точкой (12.3.1.2 Числа с плавающей 
точкой); 

- размер стека с плавающей точкой (12.3.3 Стек с плавающей точкой); 

- ширина стека с плавающей точкой (12.3.3 Стек с плавающей точкой). 

12.4.1.2 _ 

Неопределенные ситуации 

- РР§ или РР! используется с адресом, который - не выровнен как 
двойной-с-плавающей-точкой; 

- Р@ или Р! используется с адресом, который - не выровнен как с плавающей 
точкой; 

- результат с плавающей точкой вне диапазона (например, в 12.6.1.1430 Р/); 

- 5Р@ или 5Р! используется с адресом, который - не выровнен как 
единственный-с-плавающей-точкой; 

- ВАЗЕ - не десятичная (12.6.1.2143 РЕРРЕЗЕІМТ, 12.6.2.1427 Р., 12.6.2.1513 РЕ., 
12.6.2.1613 Р5.); 

- оба параметра равняются нулю (12.6.2.1489 РАТАИ2); 

- косинус параметра нулевой для 12.6.2.1625 РТАМ; 

- сі точно не может быть представлено как число с плавающей точкой в 
12.6.1.1130 Ц>Р; 

- деление на нуль (12.6.1.1430 Р/); 

- экспонента слишком большая для преобразования (12.6.2.1203 РР!, 

12.6.2.1204 РР§, 12.6.2.2202 5Р!, 12.6.2.2203 5Р§); 

- число с плавающей точкой меньше чем один (12.6.2.1477 РАСОЗН); 

- число с плавающей точкой меньше чем или равно минус-один (12.6.2.1554 РІ_МР1); 

- число с плавающей точкой меньше чем или равно нулю (12.6.2.1553 РЫМ, 

12.6.2.1557 Р1_0С); 

- число с плавающей точкой меньше чем нуль (12.6.2.1487 РА5ІІМН, 

12.6.2.1618 РЗдРТ); 

- модуль числа с плавающей точкой больше чем один (12.6.2.1476 РАС05, 
12.6.2.1486 РА5ІІМ, 12.6.2.1491 РАТАІМН); 

- целая часть числа с плавающей точкой не может быть представлена как сі в 
12.6.1.1470 Р>Ц; 

- строка больше чем область вывода отображаемого числа (12.6.2.1427 Р., 
12.6.2.1513 РЕ., 12.6.2.1613 Р5.). 

12.4.1.3 _ 

Другая системная документация 

- нет дополнительных требований. 
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12.4.2 _ 

Программная документация 

12.4.2.1 _ 

Зависимости от окружения 

- требование стека с плавающей точкой большего чем 6 элементов 
(12.3.3 Стек с плавающей точкой). 

12.4.2.2 _ 

Другая программная документация 

- нет дополнительных требований. 

12.5.1 _ 

А№ Рогіііі системы 

Фраза "Предоставляет набор слов с плавающей точкой" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов с 



плавающей точкой. 


Фраза "Предоставляет имена из расширения набора слов с плавающей точкой" должна 
быть добавлена к наименованию любой Стандартной системы, которая предоставляет 
часть расширения набора слов с плавающей точкой. 

Фраза "Предоставляет расширение набора слов с плавающей точкой" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет весь 
набор слов с плавающей точкой и расширение набора слов с плавающей точкой. 

12.5.2 _ 

А№ РогТН программы 

Фраза "Требуется набор слов с плавающей точкой" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
набор слов с плавающей точкой. 

Фраза "Требуются имена из расширения набора слов с плавающей точкой" должна 
быть добавлена к наименованию Стандартной программы, которая требует, чтобы 
система предоставила часть расширения набора слов с плавающей точкой. 

Фраза "Требуется расширение набора слов с плавающей точкой" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила весь набор слов с плавающей точкой и расширение набора слов с 
плавающей точкой. 

12.6 _ 

Словарь 

12 . 6.1 _ 

Слова с плавающей точкой 

12.6.1. Ѳ558 >Р1_0АТ "ІО-ТІоаТ" РІ.0АТІМ6 

( с-асісіг и -- Тгие | Таізе ) ( Р: -- г | ) 

или ( с-асісіг и -- г Тгие | Таізе ) 

Пытается выполнить преобразование строки определенной с-асісіг и и во 
внутреннее представление с плавающей точкой. Если строка 
представляет допустимое число с плавающей точкой в синтаксисе ниже, 
возвращает его значение г и Тгие. Если строка не представляет 
допустимое число с плавающей точкой, возвращает только Таізе. 
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Строка пробелов должна быть обработана как специальный случай 
представления нуля. 

Синтаксис преобразуемой строки := <мантисса>[<экспонента>] 
<мантисса> := [<знак>]{<цифры>[. <цифрыѲ>] | ,<цифры> } 
<экспонента> := <маркер><цифрыѲ> 

<маркер> := {<е-форма> | <знак-форма>} 

<е-форма> := <е-символ>[<знак-форма>] 

<знак-форма> := { + | - } 

<е-символ>:= { Р | б | Е | е } 

12.6.1.1130 0>Р "б-То-Т" РЦ0АТІМ6 

( б -- ) ( Р: -- г ) ог ( б -- г ) 

г - число с плавающей точкой эквивалентное б. Неопределенная 
ситуация существует если б точно не может быть представлено как 
значение с плавающей точкой. 

Р! "Т-зТоге" 

( Т-аббг - - ) ( Р: г - - ) ог ( г Т-аббг -- ) 

Сохраняет г в Т-аббг. 


12.6.1. 14ѲѲ 


РЮАТІМ6 



12.6.1.1410 Р* ’Т-зІаг" РІ_0АТІІ\І6 

( Р: П г2 -- гЗ ) ог ( г1 г2 -- гЗ ) 

Умножает гі на г2, возвращает гЗ. 


12.6.1.1420 Р+ ’Т-рІиз" РІ.0АТІМ6 

( Р: П г2 -- гЗ ) ог ( гі г2 -- гЗ ) 

Прибавляет гі к г2, возвращает сумму гЗ. 

12.6.1.1425 Р- "Лтіпиз" РІ_0АТІІ\І6 

( Р: гі г2 -- гЗ ) ог ( гі г2 -- гЗ ) 

Вычитает г2 из гі, возвращает гЗ. 


12.6.1.1430 Р/ 'Т-зІазИ" РІ.0АТІМ6 

( Р: гі г2 -- гЗ ) ог ( гі г2 -- гЗ ) 

Делит гі на г2, возвращает частное гЗ. Неопределенная ситуация 
существует если г2 нулевое, или частное находится вне диапазона 
числа с плавающей точкой. 


12.6.1.1440 РѲ< "Л 2его-1езз-1:Ііап" РІ_0АТІІ\І6 

( -- -Лад ) ( Р: г -- ) ог ( г -- Лад ) 

Лад - Ігие, если и только если г - меньше чем нуль. 

12.6.1.1450 РѲ= "Лгего-едиаіз" РЦ0АТІМ6 

( -- Лад ) ( Р: г -- ) ог ( г -- Лад ) 

Лад - Ігие, если и только если г - равно нулю. 

12.6.1.1460 р< "Ліезз-іііап" рцОАНМб 

( -- Лад ) ( Р: гі г2 -- ) ог ( гі г2 -- Лад ) 

Лад - Ігие, если и только если гі - меньше чем г2. 
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12.6.1.1470 Р>0 "ЛІО-СІ" РІ_0АТІІ\І6 

( -- сі ) ( Р: г -- ) ог ( г -- сі ) 

сі - целое число со знаком две-ячейки эквивалентное целой части из 
г. Дробная часть г откинута. Неопределенная ситуация существует, 
если целая часть г точно не может быть представлена как целое число 
со знаком две-ячейки. 

12.6.1.1472 Р@ "Л-ГеІсН" РІ.0АТІІМ6 

( Ласісіг -- ) ( Р: -- г ) ог ( Ласісіг -- г ) 
г - значение, сохраненное в Ласісіг. 

РАІЛбІЧ "Лаіідп" РЦ0АТІМ6 

( -- ) 

Если указатель области данных - не выровнен с плавающей точкой, 
резервирует достаточно пространства данных для выравнивания. 

РАШ6ІМЕ0 "Лаіідпесі" РЦ0АТІМ6 

( асісіг -- Ласісіг ) 

Ласісіг - первый с-плавающей-точкой-выровненный адрес больший или 
равный асісіг. 

12.6.1.1492 РС0ІМ5ТАІМТ " Л сопзіапі:" РІ_0АТІІЧ6 

( "<зрасез>пате" --)(Р:г--)ог(г "<зрасез>пате" -- ) 
Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения 
определенной ниже. 

пате объявлено как " Л сопзіапі:" . 


12.6.1.1479 


12.6.1.1483 


пате Выполнение: (--)(Р:--г)ог(--г) 



Помещает г на стек с плавающей точкой. 


См.: 3.4.1 Синтаксический анализ. 


12.6.1.1497 РОЕРТН "Г-сІерІІі" РІ.0АТІМ6 

( -- +п ) 

+п - число значений, содержащихся на отделенном по умолчанию стеке 
с плавающей точкой. Если числа с плавающей точкой сохраняются на 
стеке данных, +п является текущим числом возможных значений с 
плавающей точкой, содержащихся на стеке данных. 


12.6.1.1500 РОПОР ’Т-сІгор" РІ.0АТІМ6 

(Р:г--)ог(г--) 

Удаляет г со стека с плавающей точкой. 


12.6.1.1510 РОІІР ’Т-сІііре" РІ.0АТІМ6 

( Р: г -- г г ) ог ( г -- г г ) 

Дублирует г. 


12.6.1.1552 РІ_ІТЕРАІ_ 

Интерпретация: Семантика 


"Г-Іііегаі" РЦ0АТІМ6 

интерпретации для этого слова не определена. 
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Компиляция: (Р:г--)ог(г--) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. 


Время-выполнения: (Р:--г)ог(--г) 

Помещает г на стек с плавающей точкой. 

12.6.1.1555 РЦОАТ+ "Поаі-ріиз" РЦ0АТІМ6 

( -Г-асІсІгІ -- -Г-асІсІг2 ) 

Добавляет размер в адресуемых элементах числа с плавающей точкой к 
■р-асісігі, возвращает 1 = -асІсІг2. 

12.6.1.1556 РІ_0АТ5 РЦ0АТІМ6 

( п1 -- п2 ) 

п2 - размер в адресуемых элементах пі чисел с плавающей точкой. 


12.6.1.1558 РЦООР РЦ0АТІМ6 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

Округление гі к целому значению, использующему правило "округления 
к отрицательной бесконечности", возвращает г2. 


12.6.1.1562 

РМАХ 





’Т-тах" 

РЦ0АТІМ6 


( Р: гі г2 


гЗ ) 

ог ( 

гі 

г2 -- гЗ ) 



гЗ большее 

из 

гі и 

г2. 




12.6.1.1565 

РМІМ 





’Т-тіп" 

РЦ0АТІМ6 


( Р: гі г2 


гЗ ) 

ог ( 

гі 

г2 -- гЗ ) 



гЗ меньшее 

из 

гі и 

г2. 




12.6.1.1567 

РМЕ6АТЕ 





'Т-педаІе" 

РЦ0АТІМ6 


( Р: гі -- 

г2 

) ог 

( гі 


г2 ) 



г2 - отрицание гі. 

12.6.1.1600 РОѴЕП ’Т-оѵег" РЦ0АТІМ6 

( Р: гі г2 -- гі г2 гі ) ог ( гі г2 -- гі г2 гі ) 

Помещает копию гі на вершину стека с плавающей точкой. 

12.6.1.1610 РРОТ "Г-ГОІе" РЦ0АТІМ6 

( Р: гі г2 гЗ -- г2 гЗ гі ) ог ( гі г2 гЗ -- г2 гЗ гі ) 



Вращает три верхних элемента стека с плавающей точкой. 

12.6.1.1612 РРОІІШ 'Т- гоипсі" РІ.0АТІМ6 

( Р: гі -- г2 ) ог ( г1 -- г2 ) 

Округляет гі к целому значению, использующему правило "округления к 
ближайшему", возвращает г2. 

См.: 12.3.2 Операции с плавающей точкой. 

12.6.1.1620 Р5МАР "б-зиар" РІ.0АТІМ6 

( Р: гі г2 -- г2 гі ) ог ( гі г2 -- г2 гі ) 

Меняет два верхних элемента стека с плавающей точкой. 
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12.6.1.1630 РѴАРІАВІ.Е "-Г-ѵагіаЫе" РІ.0АТІМ6 

( "<зрасез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате с семантикой выполнения 
определенной ниже. Резервирует 1 РбОАТЗ адресуемый элемент области 
данных как с-плавающей-точкой-выровненный адрес. 

пате объявлено как ’Т-ѵагіаЫе" . 

пате Выполнение: ( --б-асісіг ) 

б-асісіг - адрес области данных, зарезервированной РѴАРІАВбЕ когда 
оно создавало пате. Программа ответственна за инициализацию 
содержимого зарезервированного пространства. 

См.: 3.4.1 Синтаксический анализ. 

12.6.1.2143 ПЕРРЕЗЕІМТ РІ.0АТІМ6 

( с-асісіг и -- п біаді б1ад2 ) (Р: г -- ) 
или ( г с-асісіг и -- п біаді б1ад2 ) 

В с-асісіг, помещает символьное-строковое внешнее представление 
мантиссы числа с плавающей точкой г. Возвращает п как экспоненту в 
десятичном основании, знак как біаді и "допустимый результат" как 
б1ад2. Символьная строка должна состоять из и самых старших цифр 
мантиссы представленной как десятичная дробь с подразумеваемой 
десятичной точкой слева от первой цифры, и нулевой первой цифрой 
только если все цифры нулевые. Мантисса округлена к и цифрам в 
соответствии с правилом "округления к ближайшему"; п 
откорректирован, в случае необходимости, чтобы соответствовать 
округленной величине мантиссы. Если б1ад2 - Ігие тогда г было в 
диапазоне определенных реализацией чисел с плавающей точкой. Если 
біаді - Іше тогда г - отрицательное. 

Неопределенная ситуация существует, если значение ВАЗЕ - не 
десятичное десять. 

Когда б1ад2 - баізе, п и біаді - определенное реализацией, как 
содержимое с-асісіг. При этих обстоятельствах, строка в с-асісіг должна 
состоять из графических символов. 

См.: 3.2.1.2 Преобразование цифр, 6.1.0750 ВАЗЕ, 12.3.2 Операции с 
плавающей точкой. 


12 . 6.2 _ 

Расширение слов с плавающей точкой 

12.6.2.1203 РР! "сі-б-збоге" РІ.0АТІМ6 ЕХТ 

( сіб-асісіг - - ) ( Р: г - - ) ог ( г сіб-асісіг -- ) 

Сохраняет число с плавающей точкой г в сіб-асісіг как 64-бит ІЕЕЕ 



число с двойной точностью. Если мантисса внутреннего представления 
г имеет большую точность, чем ІЕЕЕ формат с двойной точностью, оно 
должно быть округлено, используя правило "округления к ближайшему" 
Неопределенная ситуация существует, если экспонента г слишком 
большая, для размещения в ІЕЕЕ формате с двойной точностью. 
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См. : 

12.6.2.1204 


См. : 

12.6.2.1205 


См. : 

12.6.2.1207 


См. : 

12.6.2.1208 


См. : 

12.6.2.1209 


12.6.2.1415 


12.6.2.1427 


12.3.1.1 Адреса, 12.3.2 Операции с плавающей точкой. 

0І=§ "б-Г-Гебсб" РЮАТІМ6 ЕХТ 

( сІТ-асІсІг - - ) ( Р: - - г ) ог ( сІТ-асІсІг -- г ) 

Выбирает 64-бит ІЕЕЕ число с двойной точностью, сохраненное в сІТ- 
асісіг на стек с плавающей точкой как г во внутреннем представлении. 
Если ІЕЕЕ мантисса с двойной точностью имеет большую точность, чем 
внутреннее представление, оно будет округлено к внутреннему 
представлению, используя правило "округления к ближайшему". 
Неопределенная ситуация существует если экспонента ІЕЕЕ 
представления с двойной точностью слишком большая, для размещения 
во внутреннем представлении. 

12.3.1.1 Адреса, 12.3.2 Операции с плавающей точкой. 

ОРАІЛСМ "сІ-'Г-аІідп" РЮАТІМ6 ЕХТ 

( -- ) 

Если указатель области данных - выровнен не на двойное-с-плавающей- 
точкой, резервирует достаточно пространства данных для 
выравнивания. 

12.3.1.1 Адреса. 

РРАИСМЕР "б-б-аИдпесГ РЮАТІМ6 ЕХТ 

( асісіг -- сІТ-асІсІг ) 

бТ-абсІг - первый двойное-с-плавающей-точкой-выровненный адрес 
больший или равный асісіг. 

12.3.1.1 Адреса. 

ОРЦОАТ+ "сІ-ТІоаІ-рІиз" РЦ0АТІМ6 ЕХТ 

( сІТ-асШП -- сН=-асІсІг2 ) 

Добавляет размер в адресуемых элементах 64-бит ІЕЕЕ числа с двойной 
точностью к сІТ-асІсІгІ, возвращает сІТ-асІсІг2. 


12.3.1.1 Адреса. 


РРЦОАТЗ "сІ-ТІоабз" РЮАТІМ6 ЕХТ 

( п1 -- п2 ) 

п2 - размер в адресуемых элементах пі 64-бит ІЕЕЕ числа с двойной 
точностью. 


р * * 

( Р: П г2 — 
Возводит ГІ в 


"Т-збаг-збаг" 
гЗ ) ог ( г1 г2 -- гЗ ) 
степень г2, возвращает результат гЗ. 


РЮАТІМ6 ЕХТ 


Р. "Т-сІоІ" РЮАТІМ6 ЕХТ 

( -- ) ( Р: г -- ) ог ( г -- ) 

Отображает с конечным пробелом верхнее число со стека с плавающей 
точкой, используя нотацию с фиксированной точкой: 


[-] <цифры>. <цифрыѲ> 
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Неопределенная ситуация существует, если значение ВАЗЕ - не 
(десятичное) десять или если символьное строковое представление 
превышает размер буфера выходной строки отображаемого числа. 

См.: 12. 12.6.1.0558 >Р1_0АТ. 

12.6.2.1474 РАВЗ 'Т-аЬз" РІ.0АТІН6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 
г2 - абсолютное значение гі. 

12.6.2.1476 РАСОЗ "Т-а-СОЗ" РІ.0АТІН6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - главный угол в радианах, чей косинус - гі. Неопределенная 
ситуация существует, если |г1| больше единицы. 

12.6.2.1477 РАСОЗН 'Т-а-созб" РІ.0АТІН6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - значение с плавающей точкой, чей гиперболический косинус - гі. 
Неопределенная ситуация существует, если гі - меньше единицы. 

12.6.2.1484 РАІ.О0 "Т-а-1од" РІ.0АТІН6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

Возводит десять в степень гі, возвращает г2. 

12.6.2.1486 РАЗІМ "Т-а-5Іпе" РІ_0АТІН6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - главный угол в радианах, чей синус - гі. Неопределенная 
ситуация существует, если |г1| больше единицы. 

12.6.2.1487 РАЗІИН "Т-а-сіпсІі" РІ.0АТІН6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - значение с плавающей точкой, чей гиперболический синус - гі. 
Неопределенная ситуация существует, если гі - меньше единицы. 

12.6.2.1488 РАТАИ "Т-а-Нап" РІ.0АТІН6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - главный угол в радианах, чей тангенс - гі. 

12.6.2.1489 РАТАИ2 "Т-а-Іап-Іио" РЦ0АТІИ6 ЕХТ 

( Р: гі г2 -- гЗ ) ог ( гі г2 -- гЗ ) 

гЗ - угол в радианах, чей тангенс - г1/г2. Неопределенная ситуация 
существует, если гі и г2 нулевые. 

12.6.2.1491 РАТАИН "Т-а-Іап-Н" РЦ0АТІИ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - значение с плавающей точкой, чей гиперболический тангенс - гі. 
Неопределенная ситуация существует, если гі - вне диапазона с -1ЕѲ 
по 1ЕѲ. 
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12.6.2.1493 РС05 ’Т-СОЗ" РЦ0АТІИ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - косинус угла гі в радианах. 

12.6.2.1494 РС05Н 'Т-СОЗІѴ' РЦ0АТІИ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - гиперболический косинус гі. 

12.6.2.1513 РЕ. "Т-е-сЮИ" РЦ0АТІИ6 ЕХТ 

( -- ) ( Р: г -- ) ог ( г -- ) 

Отображает с конечным пробелом верхнее число со стека с плавающей 



точкой используя инженерную нотацию, где мантисса больше или равна 
1.0 и меньше чем 1Ѳ0Ѳ.0 и десятичная экспонента - множитель трех. 

Неопределенная ситуация существует, если значение ВАЗЕ - не 
(десятичное) десять или если символьное строковое представление 
превышает размер буфера выходной строки отображаемого числа. 

См.: 6.1.0750 ВАЗЕ, 12.3.2 Операции с плавающей точкой, 12.6.1.2143 
РЕРРЕ5ЕМТ. 


12.6.2.1515 

РЕХР 





"-(=_е-х-р м 

РЦ0АТІМ6 

ЕХТ 


( Р: гі - 

- 

г2 

) ог ( 

гі 

-- г2 ) 




Возводит 

е 

в 

степень 

П, 

возвращает г2. 



12.6.2.1516 

РЕХРМ1 





"Т-е-х-р-ш-опе" 

РЦ0АТІМ6 

ЕХТ 


( Р: гі - 

- 

г2 

) ог ( 

гі 

-- г2 ) 




Возводит 

е 

в 

степень 

гі, 

и вычитает один, 

возвращает г2. 


12.6.2.1553 

рци 





"Т-1-п" 

РЦ0АТІМ6 

ЕХТ 


( Р: гі - 

- 

г2 

) ог ( 

гі 

-- г2 ) 




г2 - натуральный логарифм гі. Неопределенная ситуация существует 
если гі - меньше или равно нулю. 

12.6.2.1554 РІ.МР1 ’Т-І-П-р-Опе" РЦ0АТІМ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - натуральный логарифм величины гі плюс один. Неопределенная 
ситуация существует если гі - меньше или равно минус один. 

12.6.2.1557 РЦО0 ’Т-Іод" РЦ0АТІМ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - десятичный логарифм гі. Неопределенная ситуация существует 
если гі меньше или равно нулю. 

12.6.2.1613 Р5. "Т-5-СІОІ:" РЦ0АТІМ6 ЕХТ 

( -- ) ( Р: г -- ) ог ( г -- ) 

Отображает, с конечным пробелом, верхнее число со стека с плавающей 
точкой в экспоненциальном формате: 
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<мантисса><экспонента> 

где: 

<мантисса> := [-]<цифра>.<цифрыѲ> 

<экспонента> := Е[-]<цифры> 

Неопределенная ситуация существует, если значение ВАЗЕ - не 
(десятичное) десять или если символьное строковое представление 
превышает размер буфера выходной строки отображаемого числа. 

См.: 6.1.0750 ВАЗЕ, 12.3.2 Операции с плавающей точкой, 12.6.1.2143 
РЕРРЕЗЕІМТ. 


12.6.2.1614 

РЗІМ 



"Т-зіпе" 


РЦОАТІИб 

ЕХТ 


( Р: 

гі -- 

г2 ) ог 

( 

гі -- г2 ) 





г2 - 

синус 

угла гі 

в 

радианах . 




12.6.2.1616 

Р5ІМС05 



"Т-зіпе-соз" 

РЮАТІМ6 

ЕХТ 


( Р: 

гі -- 

г2 гЗ ) 

ог 

( П -- г2 гЗ 

) 




г2 - 

синус 

угла гі 

в 

радианах. гЗ - 

косинус угла гі в 

радианах . 


12.6.2.1617 

Р5ІМН 



"Т-сіпсП 

II 

РЕ0АТІИ6 

ЕХТ 


( Р : 

гі -- 

г2 ) ог 

( 

гі -- г2 ) 





г2 - 

гиперболический 

синус гі. 






12.6 


12.6 


12.6 


12.6 


12.6 


12.6 


12.6 


12.6 


2.1618 РЗдРТ 'Т-зциаге- гооі:" РІ.0АТІМ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - квадратный корень гі. Неопределенная ситуация существует, если 
гі - меньше нуля. 

2.1625 РТАИ 'Т-Іап" РЦ0АТІМ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - тангенс угла гі в радианах. Неопределенная ситуация существует 
если соз(гі) нулевое. 

2.1626 РТАІМН "Т-Іап-Н" РЦ0АТІМ6 ЕХТ 

( Р: гі -- г2 ) ог ( гі -- г2 ) 

г2 - гиперболический тангенс гі. 

2.1640 Р~ "Т-ргохітаІе" РЦ0АТІМ6 ЕХТ 

( -- Тіад ) ( Р: гі г2 гЗ -- ) ог ( гі г2 гЗ -- Тіад ) 

Если гЗ положительно, "Лад - Іше если абсолютное значение (гі 
минус г2) меньше чем гЗ. 

Если гЗ нулевое, Лад - Іше если зависящее-от-реализации 
кодирование гі и г2 точно идентично (положительный и отрицательный 
нуль неравны если они имеют различное кодирование). 
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Если гЗ - отрицательное, "Лад - Іше если абсолютное значение (гі 
минус г2) меньше чем абсолютное значение гЗ умноженное на сумму 
абсолютных значений гі и г2. 

2.2035 РРЕСІ5І0М РЦ0АТІМ6 ЕХТ 

( -- и ) 

Возвращает число и значащих цифр, в настоящее время используемых в 
Р., РЕ., или Р5.. 

2.2200 ЗЕТ -РКЕСІЗІОИ РЦ0АТІМ6 ЕХТ 

( и -- ) 

Устанавливает число и значащих цифр, в настоящее время используемых 
в Р., РЕ., или Р5.. 

2.2202 5Р! "з-Т-зІоге" РЦ0АТІМ6 ЕХТ 

( зТ-асІсІг - - ) ( Р: г - - ) ог ( г зТ-асІсІг -- ) 

Сохраняет число с плавающей точкой г как 32-бит ІЕЕЕ с одинарной 
точностью число в зТ-асісІг. Если мантисса внутреннего представления 
г имеет большую точность чем ІЕЕЕ формат с одинарной точностью, оно 
будет округленно с использованием правила "округления к 
ближайшему". Неопределенная ситуация существует если экспонента г 
слишком большая, чтобы быть размещенной в формате ІЕЕЕ с одинарной 
точностью. 

См.: 12.3.1.1 Адреса, 12.3.2 Операции с плавающей точкой. 

2.2203 5Р@ "з-Г-ТеИсМ" РЦ0АТІМ6 ЕХТ 

( зТ-асісІг - - ) ( Р: - - г ) ог ( зТ-асісІг -- г ) 

Выбирает 32-бит ІЕЕЕ число с одинарной точностью, сохраненное в зТ- 
асісіг на стек с плавающей точкой как г во внутреннем представлении. 
Если ІЕЕЕ мантисса с одинарной точностью имеет большую точность чем 
внутреннее представление, оно будет округлено к внутреннему 
представлению с использованием правила "округления к ближайшему". 
Неопределенная ситуация существует если экспонента ІЕЕЕ 
представления с одинарной точностью слишком большая, чтобы быть 
размещенной во внутреннем представлении. 



См.: 12.3.1.1 Адреса, 12.3.2 Операции с плавающей точкой. 

12.6.2.2204 ЗРАІЛбИ "5-Г-аІІдп" РЦ0АТІМ6 ЕХТ 

( -- ) 

Если указатель области данных - выровнен не на одинарное-с- 
плавающей-точкой, резервирует достаточно пространства данных для 
выравнивания. 

См.: 12.3.1.1 Адреса. 

12.6.2.2206 5РАИ6МЕ0 "з-'Р-аІідпесі" РІ.0АТІН6 ЕХТ 

( асісіг -- зТ-асІсІг ) 

зТ-асІсІг - первый одинарный-с-плавающей-точкой-выровненный адрес 
больший или равный асісіг. 

См.: 12.3.1.1 Адреса. 
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12.6.2.2207 5РЦ0АТ+ "з-ПоаІі-рІиз" РЦ0АТІМ6 ЕХТ 

( зТ-асІсІгІ -- зТ-асісІг2 ) 

Прибавляет размер в адресуемых элементах 32-бит ІЕЕЕ числа с 
одинарной точностью к зТ-асІсІгІ, возвращает зТ-асІсІг2. 

См.: 12.3.1.1 Адреса. 

12.6.2.2208 5РІ_0АТ5 "з-ПоаІіз" РЦ0АТІМ6 ЕХТ 

( п1 -- п2 ) 

п2 - размер в адресуемых элементах пі 32-бит ІЕЕЕ чисел с одинарной 
точностью. 

См.: 12.3.1.1 Адреса. 
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13. _ 

Дополнительный набор слов І_оса1з 

13.1 _ 

Введение 

См.: Приложение А. 13 І_оса1з набор слов. 

13.2 _ 

Дополнительные термины и нотации 


Нет. 

13.3 _ 

Дополнительные условия применения 

13.3.1 _ 

Цосаіз 

Іосаі - объект данных, чья семантика выполнения должна возвратить его значение, 
чей контекст должен быть ограничен определением в котором он объявлен, и чье 
использование в определении не должно препятствовать повторной входимости или 
рекурсии. 


13.3.2 


Запросы к окружению 



Добавьте таблицу 13.1 к таблице 3.5. 
См.: 3.2.6 Запросы к окружению. 


Таблица 13.1 - Строки запросов к окружению 


Строка 

Тип 

Константа 

Значение 

#І_0САІ_5 

п 

уез 

максимальное 

число Іосаі переменных в 




определении 


І_0САІ_5 

Тіад 

по 

Іосаіз набор 

слов присутствует 

І_0САІ_5-ЕХТ 

Тіад 

по 

дополнительный Іосаіз набор слов присутствует 


13.3.3 _ 

Обработка Іосаіз 

Чтобы поддерживать набор слов Іосаіз, система должна предоставить механизм для 
получения сообщений определенных с помощью( І_ОСАІ_) и реагировать как описано 
здесь. 

В течение компиляции определения после : (двоеточие), :І\ІСШАМЕ, или 00Е5>, 
программа может начинать посылать системе сообщения Іосаі идентификатора. 
Процесс должен начаться, когда послано первое сообщение. Процесс должен 
закончиться, когда послано "последнее Іосаі" сообщение. Система должна 
отслеживать имена, порядок, и число идентификаторов, содержащихся в законченной 
последовательности. 

13.3.3.1 _ 

Семантика компиляции 

Система при получении последовательности сообщения Іосаі-идентификатора должна 
выполнять следующие действия во время компиляции: 
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a) Создать временные входы словаря для каждого из идентификаторов, переданного 
в ( І_ОСАІ_ ) так, что каждый идентификатор будет вести себя как Іосаі. Эти 
временные входы словаря должны исчезнуть в конце определения обозначенного 

; (точка с запятой), ;С(ЮЕ, или Р0Е5>. Система не обязана поддерживать эти 
идентификаторы таким же образом как она делает другие входы словаря, чтобы 
они могли быть найдены нормальным процессом поиска в словаре. Кроме того, 
если набор слов Зеагсб-Огсіег присутствует, идентификаторы Іосаі должны 
всегда искаться перед любым из списков слов в любом определимом порядке 
поиска, и ни одно из слов Зеагсб-Огсіег не должно изменять Іосаіз 1 
привилегированную позицию в порядке поиска. І_оса1 идентификаторы могут 
находиться на запоминающем устройстве. 

b) Для каждого идентификатора переданного в (І_ОСАІ_), система должна 
генерировать соответствующую кодовую последовательность, которая делает 
следующее во время выполнения: 

1) Распределяет ресурс памяти, способный содержать значение Іосаі. Память 
должна быть распределена способом, который не препятствует повторной 
входимости или рекурсии в определении использующем Іосаі. 

2) Инициализирует значение, используя верхний элемент на стеке данных. 

Если объявлен больше чем один Іосаі, верхний элемент на стеке должен 
быть перемещен в Іосаі идентифицированный первым, следующий элемент 
должен быть перемещен во второй, и так далее. 

Ресурс памяти может быть стеком возвратов или может быть реализован другим 
способом, таким как регистры. Ресурс памяти не должен быть стеком данных. 
Использование Іосаіз не должно ограничивать использование стека данных 
прежде или после точки объявления. 

c) Принимается, что любой из законных методов завершения выполнения 





определения, конкретно: ; (точка с запятой), ;С(ЮЕ, Р0Е5> или ЕХІТ, 
освободит ресурс памяти распределенный для Іосаіз, если таковые вообще 
имеются, объявленный в этом определении. АБОРТ должно освободить все 
ресурсы памяти Іосаі, и САТСН / ТИРОМ (если реализовано) должны освободить 
такие ресурсы для всех определений, чье выполнение заканчивается. 

сі) Отдельные наборы Іосаіз могут быть объявлены в определяющих словах перед 
00Е5> для использования определяющим словом, и после 00Е5> для 
использования определяемым словом. 

Система, реализующая набор слов І_оса1з должна поддерживать объявление по 

крайней мере восьми Іосаіз в определении. 

13.3.3.2 _ 

Ограничения Синтаксиса 

Слова немедленного исполнения в программе могут использовать ( І_ОСАІ_) , чтобы 

осуществить синтаксисы для объявлений Іосаі со следующими ограничениями: 

a) Программа не должна компилировать никакой выполнимый код в текущее 
определение между временем выполнения (І_0СА1_), чтобы идентифицировать 
первый Іосаі для этого определения и временем посылки единственного 
требуемого "последнего Іосаі" сообщения; 

b) Позиция в источнике программы в которой послана последовательность (І_ОСАІ_) 
сообщений, упомянутая здесь как точка в которой объявлен Іосаіз, не должна 
лежать в пределах области любой управляющей структуры; 

c) І_оса1з не должны быть объявлены пока не были удалены значения, 
предварительно помещенные на стек возвратов в пределах определения; 

сі) После того, как Іосаіз определения были объявлены, программа может помещать 
данные на стек возвратов. Однако если это сделано, Іосаіз не будут 
доступны, пока эти значения не будут удалены со стека возвратов; 

е) Слова, которые возвращают идентификаторы исполнения, типа ' (Иск), ['], 
или РІІ\Ю, не должны использоваться с Іосаі именами; 

Т) Программа, которая объявляет больше чем восемь Іосаіз в отдельном 
определении, имеет зависимость от окружения; 
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д) І_оса1з могут быть доступны или модифицированы в пределах управляющих 
структур, включая сіо-іоорз; 

И) На Іосаі имена нельзя ссылаться посредством Р05ТР0ІМЕ и [СОМРШЕ] . 

См.: 3.4 Интерпретатор текста РогІИ. 

13.4 _ 

Дополнительные документационные требования 

13.4.1 _ 

Системная документация 

13.4.1.1 _ 

Опции определенные реализацией 

- максимальное число Іосаіз в определении (13.3.3 Обработка Іосаіз, 
13.6.2.1795 І_0САІ_5 [ ) . 

13.4.1.2 _ 

Неопределенные ситуации 

- выполнение именованного Іосаі, в состоянии интерпретации 
(13.6.1.0086 ( І_0САІ_) ); 

- имя, не определенное с помощью ѴАШЕ или І_0САІ_ (13.6.1.2295 ТО). 


13.4.1.3 



Другая системная документация 


- нет дополнительных требований. 

13.4.2 _ 

Программная документация 

13.4.2.1 _ 

Зависимости от окружения 

- объявление больше чем восемь Іосаіз в отдельном определении 
(13.3.3 Обработка Іосаіз). 

13.4.2.2 _ 

Другая программная документация 

- нет дополнительных требований. 

13.5 _ 

Соглашение и наименование 

13.5.1 _ 

А№ Рогій системы 

Фраза "Предоставляет І_оса1з набор слов" должна быть добавлена к наименованию 
любой Стандартной системы, которая предоставляет весь І_оса1з набор слов. 

Фраза "Предоставляет имена из расширения І_оса1з набора слов" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет часть 
расширения І_оса1з набора слов. 

Фраза "Предоставляет расширение І_оса1з набора слов" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь І_оса1з набор 
слов и расширение І_оса1з набора слов. 

13.5.2 _ 

А№ Рогій программы 
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Фраза "Требуется І_оса1з набор слов" должна быть добавлена к наименованию 
Стандартной программы, которая требует, чтобы система предоставила І_оса1з набор 
слов. 

Фраза "Требуются имена из расширения І_оса1з набора слов" должна быть добавлена 
к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения І_оса1з набора слов. 

Фраза "Требуется расширение І_оса1з набора слов" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь І_оса1з набор слов и расширение І_оса1з набора слов. 

13.6 _ 

Словарь 

13.6.1 _ 

І_оса1з слова 

13.6.1.0086 ( І_ОСАІ_ ) "рагеп-іосаі-рагеп" І_ОСАІ_ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: ( с-асісіг и -- ) 

Когда выполнено в течение компиляции, (І_ОСАІ_) посылает сообщение 



системе, которое имеет одно из двух значений. Если и ненулевое, 
сообщение идентифицирует новый Іосаі, чье имя определения дается 
строкой символов идентифицированной с-асісіг и. Если и нулевое, 
сообщение - "последний Іосаі" и с-асісіг не имеет никакого значения. 

Результат выполнения (І_ОСАІ_) в течение компиляции определения - 
создание набора именованных Іосаі идентификаторов, каждый из 
которых - имя определения которое имеет только семантику выполнения 
в пределах этого источника определений. 

Іосаі Выполнение: ( -- х ) 

Помещает значение Іосаі, х на стек. Значение Іосаі инициализировано 
как описано в 13.3.3 Обработка Іосаіз, и может быть изменено с 
помощью ТО предшествующим имени Іосаі. Неопределенная ситуация 
существует когда Іосаі выполнено в состоянии интерпретации. 

Примечание: Это слово не имеет специальной семантики компиляции в 
обычном смысле, потому что оно предоставляет доступ к системной 
возможности использования другими пользователем-определенными 
словами, которые его включают. Однако, средство Іосаіз в целом и 
последовательность посылаемых сообщений, определяет специфические 
правила использования с семантическими значениями, которые описаны 
подробно в разделе 13.3.3 Обработка Іосаіз. 

Примечание: Это слово не предназначено для прямого использования в 
определении, для объявления этих Іосаіз определений. Оно вместо 
этого используется системными или пользовательскими компилирующими 
словами. Эти компилирующие слова в свою очередь определяют их 
собственный синтаксис, и могут использоваться непосредственно в 
определениях для объявления Іосаіз. В этом контексте, синтаксис для 
( І_ОСАІ_ ) определен в терминах последовательности сообщений времени- 
компиляции и описан подробно в разделе 13.3.3 Обработка Іосаіз. 
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Примечание: Набор слов І_оса1з изменяет синтаксис и семантику 6.2.2295 
ТО как определено в расширении основного набора слов. 

См.: 3.4 Интерпретатор текста РогИ'і. 

13.6.1.2295 ТО І_ОСАІ_ 

Расширьте семантику 6.2.2295 ТО таким образом: 

Интерпретация: ( х "<зрасез>пате" -- ) 

Пропускает ведущие пробелы, и выделяет пате, ограниченное пробелом. 
Сохраняет х в пате. Неопределенная ситуация существует, если пате 
не было определено с помощью ѴАШЕ. 

Компиляция: ( "<зрасез>пате" -- ) 

Пропускает ведущие пробелы, и выделяет пате, ограниченное пробелом. 
Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. Неопределенная ситуация существует, если пате не было 
определено с помощью ѴАШЕ или (І_ОСАІ_). 

Время-выполнения: ( х -- ) 

Сохраняет х в пате. 

Примечание: Неопределенная ситуация существует, если РОЗТРСШЕ или 
[СОМРШЕ], применяется к ТО. 


См.: 3.4.1 Синтаксический анализ, 6.2.2295 ТО, 6.2.2405 ѴАШЕ, 
13.6.1.0086 ( І_ОСАІ_ ) . 



13.6.2 _ 

Расширения І_осаІ5 слов 

13.6.2.1795 І_0САІ_5 1 "1осаІ5-Ьаг" І.ОСАІ. ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( "<зрасе5>пате1" "<5расез>пате2" 

... "<зрасез>патеп" "|" -- ) 

Создает до восьми идентификаторов Іосаі, периодически пропуская 
ведущие пробелы, выделя пате, и выполняя 13.6.1.0086 (І_ОСАІ_). 

Список Іосаіз, который будет определен, заканчивается |. Добавляет 
семантику времени-выполнения данную ниже к текущему определению. 

Время-выполнения: ( хп ... х2 хі -- ) 

Инициализирует до восьми идентификаторов Іосаі как описано в 
13.6.1.0086 (ДОСАД), каждый из которых берет как его начальное 
значение верхний элемент стека, удаляя его со стека. Идентификатор 
патеі инициализирован хі, идентификатор пате2 - х2, и т.д. При 
вызове, каждый Іосаі будет возвращать его значение. Значение Іосаі 
может быть изменено, использованием 13.6.1.2295 ТО. 
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14. _ 

Дополнительный набор слов распределения памяти 

14.1 _ 

Введение 

14.2 _ 

Дополнительные термины и нотация 

Нет. 

14.3 _ 

Дополнительные условия применения 

14.3.1 _ 

Тип данных результата ввода-вывода 

Результат ввода - числа одна-ячейка, указывающие результат операций ввода- 
вывода. Значение нуль указывает, что операция ввода-вывода завершилась успешно; 
другие значения и их смысл - определенное реализацией. 


Добавьте таблицу 14 

.1 к таблице 3.1. 


Таблица 14.1 - 

Типы данных 


Символ 

Тип данных 

Размер на стеке 

іог 

результат ввода-вывода 

1 ячейка 


14.3.2 _ 

Запросы к окружению 

Добавьте таблицу 14.2 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 14.2 - Строки запросов к окружению 





Строка 


Тип 


Константа 


Значение 


МЕМОРѴ-АНОС "Лад по набор слов распределения памяти присутствует 

МЕМОРѴ-АШЭС-ЕХТ "Лад по дополнительный набор слов распределения 

памяти присутствует 


14.3.3 _ 

Распределенные области 

Программа может адресовать память в зонах области данных, сделанных доступными 
с помощью АШЭСАТЕ или РЕ5І2Е и еще не освобожденными с помощью РРЕЕ. 

См.: 3.3.3 Области данных. 

14.4 _ 

Дополнительные документационные требования 

14.4.1 _ 

Системная документация 
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14.4.1.1 _ 

Опции определенные реализацией 

- смысл и значение іог (14.3.1 Тип данных результата ввода-вывода, 

14.6.1.0707 АШОСАТЕ, 14.6.1.1605 РРЕЕ, 14.6.1.2145 КЕ5І2Е) . 

14.4.1.2 _ 

Неопределенные ситуации 

- нет дополнительных требований. 

14.4.1.3 _ 

Другая системная документация 

- нет дополнительных требований. 

14.4.2 _ 

Программная документация 

- нет дополнительных требований. 

14.5 _ 

Соглашение и наименование 

14.5.1 _ 

А№ РогІП системы 

Фраза "Предоставляет набор слов распределения памяти" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов 
распределения памяти. 

Фраза "Предоставляет имена из расширения набора слов распределения памяти" 
должна быть добавлена к наименованию любой Стандартной системы, которая 
предоставляет часть расширения набора слов распределения памяти. 

Фраза "Предоставляет расширение набора слов распределения памяти" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет весь 
набор слов распределения памяти и расширение набора слов распределения памяти. 





14.5.2 _ 

А№ Рогіб программы 

Фраза "Требуется набор слов распределения памяти" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
набор слов распределения памяти. 

Фраза "Требуются имена из расширения набора слов распределения памяти" должна 
быть добавлена к наименованию Стандартной программы, которая требует, чтобы 
система предоставила часть расширения набора слов распределения памяти. 

Фраза "Требуется расширение набора слов распределения памяти" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила весь набор слов распределения памяти и расширение набора слов 
распределения памяти. 

14.6 _ 

Словарь 

14.6.1 _ 

Слова распределения памяти 

14.6.1.Ѳ7Ѳ7 АШОСАТЕ МЕМОКѴ 

( и -- а-асісіг іог ) 
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Распределяет и адресуемых элементов непрерывной области данных. 
Указатель области данных не затронут этой операцией. Начальное 
содержимое распределенного пространства не определено. 

Если распределение успешное, а-асісіг - выровненный стартовый адрес 
распределенного пространства и іог нулевое. 

Если операция ошибочна, а-асісіг не представляет допустимый адрес и 
іог - код завершения ввода-вывода определенный реализацией. 

См.: 6.1.1650 НЕКЕ, 14.6.1.1605 РКЕЕ, 14.6.1.2145 КЕ5І2Е. 

14.6.1.1605 РКЕЕ МЕМОКѴ 

( а-асісіг -- іог ) 

Возвращает непрерывную зону области данных, обозначенную а-асісіг в 
систему для последующего распределения, а-асісіг должен указать зону 
области данных, которая была предварительно получена с помощью 
АШОСАТЕ или КЕ5І2Е. Указатель области данных не затронут этой 
операцией. 

Если операция успешна, іог нулевое. Если операция ошибочна, іог - 
код завершения ввода-вывода определенный реализацией. 

См.: 6.1.1650 НЕКЕ, 14.6.1.0707 АШОСАТЕ, 14.6.1.2145 КЕ5І2Е. 

14.6.1.2145 КЕ5І2Е МЕМОКѴ 

( а-асісігі и -- а-асісІг2 іог ) 

Изменяет распределение непрерывной области данных, начинающейся с 
адреса а-асісігі, предварительно распределенной АШОСАТЕ или КЕ5І2Е, 
до и адресуемых элементов, и может быть или больше или меньше чем 
текущий размер зоны. Указатель области данных не затронут этой 
операцией. 


Если операция успешна, а-абсІг2 - выровненный стартовый адрес и 
адресуемых элементов распределенной памяти и іог нулевое. а-абсІг2 
может быть, но не обязательно, такой же как а-асісігі . Если они - не 



равны, значения содержащиеся в области а-асісігі скопированы в а- 
асІсІг2, до минимального размера любой из этих двух областей. Если 
они равны, значения содержащиеся в области сохраняются по минимуму 
и или первоначального размера. Если а-асІсІг2 - не такой же как а- 
асісігі, область памяти а-асісігі возвращается системе согласно 
операции РКЕЕ. 

Если операция ошибочна, а-асІсіг2 равен а-асісігі, область памяти а- 
асісігі не затронута, и іог - код результата ввода-вывода 
определенный реализацией. 

См.: 6.1.1650 НЕКЕ, 14.6.1.0707 АШОСАТЕ, 14.6.1.1605 РРЕЕ. 


14.6.2 _ 

Расширения слов распределения памяти 


Нет. 
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15. _ 

Дополнительный набор слов утилит 

15.1 _ 

Введение 

Этот дополнительный набор слов содержит слова, наиболее часто используемые в 
течение разработки приложения. 

15.2 _ 

Дополнительные термины и нотация 

Нет. 

15.3 _ 

Дополнительные условия применения 

15.3.1 _ 

Запросы к окружению 

Добавьте таблицу 15.1 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 15.1 - Строки запросов к окружению 

Строка Тип Константа Значение 


Т00І_5 "Лад по набор слов утилит присутствует 

Т00І_5-ЕХТ "Лад по дополнительный набор слов утилит присутствует 


15.3.2 _ 

Словарь РогІН 

Программа, использующая слова СОРЕ или ;СООЕ, связанные с кодом ассемблера 
имеет зависимость от окружения на этой специфической системе команд и нотации 
ассемблера. 


Программы, использующие слова ЕОІТОР или А55ЕМВ1_ЕК требуют набора слов Порядка 
поиска или эквивалентную определенную реализацией возможность. 





См.: 3.3 Словарь Рогій. 


15.4 _ 

Дополнительные документационные требования 

15.4.1 _ 

Системная документация 

15.4.1.1 _ 

Опции определенные реализацией 

- завершающая последовательность для входного потока 15.6.2.0470 ;С0РЕ и 
15.6.2.0930 СОРЕ; 

- способ обработки входного потока 15.6.2.0470 ;С0РЕ и 15.6.2.0930 СОРЕ; 

- возможность порядка поиска для 15.6.2.1300 ЕОІТОР и 15.6.2.0740 А55ЕМВІ_ЕР 
(15.3.3 Словарь Рогій); 

- источник и формат отображения с помощью 15.6.1.2194 5ЕЕ. 

15.4.1.2 _ 

Неопределенные ситуации 
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- удаление списка слов компиляции (15.6.2.1580 Р0Р6ЕТ); 

- количество элементов на стеке потока управления меньше чем и+1 
(15.6.2.1015 С5РІСК, 15.6.2.1020 С5Р0І_І_); 

- имя не может быть найдено (15.6.2.1580 Р0Р6ЕТ); 

- имя не определено через 6.1.1000 СРЕАТЕ (15.6.2.0470 ;С00Е); 

- 6.1.2033 РОЗТРОИЕ применено к 15.6.2.2532 [ІР] ; 

- достижение конца входного источника перед согласованием 15.6.2.2531 [ЕІ_5Е] 

ИЛИ 15.6.2.2533 [ТНЕІМ] (15.6.2.2532 [ІР]); 

- удаление необходимого определения (15.6.2.1580 Р0Р6ЕТ). 

15.4.1.3 _ 

Другая системная документация 

- нет дополнительных требований. 

15.4.2 _ 

Программная документация 

15.4.2.1 _ 

Зависимости от окружения 

- использование слов 15.6.2.0470 ;С0РЕ или 15.6.2.0930 СООЕ. 

15.4.2.2 _ 

Другая программная документация 

- нет дополнительных требований. 

15.5 _ 

Соглашение и наименование 

15.5.1 _ 

А№ Рогіб системы 

Фраза "Предоставляет набор слов утилит" должна быть добавлена к наименованию 
любой Стандартной системы, которая предоставляет весь набор слов утилит. 

Фраза "Предоставляет имена из расширения набора слов утилит" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет часть 
расширения набора слов утилит. 



Фраза "Предоставляет расширение набора слов утилит" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов 
утилит и расширение набора слов утилит. 

15.5.2 _ 

А№ Рогбб программы 

Фраза "Требуется набор слов утилит" должна быть добавлена к наименованию 
Стандартной программы, которая требует, чтобы система предоставила набор слов 
утилит. 

Фраза "Требуются имена из расширения набора слов утилит" должна быть добавлена 
к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения набора слов утилит. 

Фраза "Требуется расширение набора слов утилит" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь набор слов утилит и расширение набора слов утилит. 
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15.6 _ 

Словарь 

15.6.1 _ 

Слова Утилит 

15.6.1.0220 .5 "СІОІ-З" Т00І.5 

( -- ) 

Копирует и отображает значения находящиеся на стеке данных. Формат 
отображения зависящий-от-реализаци. 

.5 может быть реализовано с использованием слов вывода отображаемых 
чисел. Следовательно, его использование может разрушать временную 
область, идентифицированную #>. 

См.: 3.3.3.6 Другие временные области. 

15.6.1.0600 ? "цііезбіоп" Т00І.5 

( а-асісіг -- ) 

Отображает значение, сохраненное в а-асісіг. 

? может быть реализовано, с использованием слов вывода отображаемых 
чисел. Следовательно, его использование может разрушать временную 
область, идентифицированную #>. 

См.: 3.3.3.6 Другие временные области. 

15.6.1.1280 ОІІМР Т00І_5 

( асісіг и -- ) 

Отображает содержание и последовательных адресов, начинающихся с 
асісіг. Формат отображения зависящий от реализации. 

РІІМР может быть реализовано, с использованием слов вывода 
отображаемых чисел. Следовательно, его использование может 
разрушать временную область, идентифицированную #>. 

См.: 3.3.3.6 Другие Временные Области. 

15.6.1.2194 ЗЕЕ Т00Ц5 

( "<зрасез>пате" -- ) 

Отображает удобочитаемое представление определения именованного 



слова. Источник представления (декомпиляция объектного кода, блок 
источника, и т.д.) и специфическая форма отображения - определенное 
реализацией. 

5ЕЕ может быть реализовано, с использованием слов вывода 
отображаемых чисел. Следовательно, его использование может 
разрушать временную область, идентифицированную #>. 

См.: 3.3.3.6 Другие временные области. 

15.6.1.2465 МОРОЗ Т00Ц5 

( -- ) 

Перечисляет имена определений в первом списке слов порядка поиска. 
Формат отображения зависящий-от-реализаци. 
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МОРОЗ может быть реализовано, с использованием слов вывода 
отображаемых чисел. Следовательно, его использование может 
разрушать временную область, идентифицированную #>. 

См.: 3.3.3.6 Другие Временные Области. 


15.6.2 _ 

Расширения слов Утилит 

15.6.2.0470 ;СОРЕ "зешісоіоп-сосіе" Т00І_5 ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: ( С: соіоп-зуз -- ) 

Добавляет семантику времени-выполнения ниже к текущему определению. 
Заканчивает текущее определение, позволяя ему быть найденным в 
словаре, и вводит состояние интерпретации, потребляя соіоп-зуз. 

Последующие символы в области анализа типично представляют исходный 
текст на языке программирования, обычно некоторой формы ассемблера. 
Эти символы, обработанные определенным реализацией способом, 
производят соответствующий машинный код. Процесс продолжается, 
пополнением входного буфера по мере необходимости, до обработки 
определенной реализацией завершающей последовательности. 

Время-выполнения: ( -- ) ( П: пезі-зуз -- ) 

Заменяет семантику выполнения самого последнего определения на 
семантику выполнения пате, данную ниже. Возвращает управление на 
вызывающее определение, определенное пезі-зуз. Неопределенная 
ситуация существует если самое последнее определение не было 
определено с помощью СПЕАТЕ или определенного пользователем слова, 
которое вызывает СПЕАТЕ. 

пате Выполнение: ( і*х -- д*х ) 

Исполняет машинную последовательность кода, которая была 
сгенерирована после ;СООЕ. 

См.: 6.1.1250 00ЕЗ> . 

15.6.2.0702 АНЕАО Т00Ц5 ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Компиляция: (С: -- огід ) 

Помещает адрес ячейки новой неразрешенной ссылки вперед огід на 
стек потока управления. Добавляет семантику времени-выполнения, 
данную ниже к текущему определению. Семантика не завершена, пока 
огід не разрешена (например, с помощью ТНЕІМ). 



Время-выполнения: ( -- ) 

Продолжает выполнение с адреса ячейки, определенного разрешением 
огід . 

15.6.2.Ѳ740 А55ЕМВІ.ЕВ Т00І.5 ЕХТ 

( -- ) 

Заменяет первый список слов в порядке поиска на список слов 
А55ЕМВІ_ЕК. 

См.: 16. Дополнительный набор слов порядка поиска. 
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15.6.2.0830 ВУЕ Т00І.5 ЕХТ 

( -- ) 

Возвращает управление в базовую операционную систему, если 
существует. 

15.6.2.0930 СОРЕ Т00І.5 ЕХТ 

( "<5расез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Создает определение для пате, обозначенное "сосіе 
сіеііпіііоп", с семантикой выполнения определенной ниже. 

Последующие символы в области анализа типично представляют исходный 
текст на языке программирования, обычно некоторой формы ассемблера. 
Эти символы, обработанные определенным реализацией способом, 
производят соответствующий машинный код. Процесс продолжается, 
пополнением входного буфера по мере необходимости, до обработки 
определенной реализацией завершающей последовательности. 

пате Выполнение: ( і*х -- д*х ) 

Исполняет машинную последовательность кода, которая была 
сгенерирована после СООЕ. 

См.: 3.4.1 Синтаксический анализ. 

15.6.2.1015 С5-РІСК "с-5-рІск" Т00І_5 ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение^ С: сіезіи ... огідѲ | сІезіѲ -- сіезіи ... огідѲ | сІезіѲ сіезіи ) 

( 5: и -- ) 

Удаляет и. Копирует сіезіи на вершину стека потока управления. 
Неопределенная ситуация существует, если есть меньше чем и+1 
элементов, каждый из которых должен быть огід или сіезі, на стеке 
потока управления перед выполнением С5-РІСК. 

Если стек потока управления реализован с использованием стека 
данных, и должен быть самым верхним элементом на стеке данных. 

15.6.2.1020 С5-Р0Ш "С-5-Г0І1" Т00І_5 ЕХТ 

Интерпретация: Семантика интерпретации для этого слова не определена. 

Выполнение: ( С: огіди | сіезіи огіди-1 1 сіезіи-і ... огідѲ | сІезіѲ -- 

огіди-1 [ сіезіи-і ... огідѲ | СІезІіѲ огіди | сіезіи ) 

( 5: и -- ) 

Удаляет и. Вращает и+1 элементов на вершине стека потока управления 
так, чтобы огіди | сіезіи находились на вершине стека потока 
управления. Неопределенная ситуация существует, если есть меньше 
чем и+1 элементов, каждый из которых должен быть огід или сіезі, на 
стеке потока управления перед выполнением С5-Р0Ш. 



Если стек потока управления реализован с использованием стека 
данных, и должен быть самым верхним элементом на стеке данных. 
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15.6.2.1300 ЕОІТОР Т00І.5 ЕХТ 

( -- ) 

Заменяет первый список слов в порядке поиска на список слов ЕОІТОР. 

См.: 16. Дополнительный набор слов порядка поиска. 

15.6.2.1580 РОРСЕТ Т00І.5 ЕХТ 

( "<зрасез>пате" -- ) 

Пропускает ведущие разделители пробелы. Выделяет пате, ограниченное 
пробелом. Находит пате, затем удаляет пате из словаря наряду со 
всеми словами, добавленными в словарь после пате. Неопределенная 
ситуация существует, если пате не может быть найдено. 

Если набор слов Порядка поиска присутствует, Р0Р6ЕТ исследует 
список слов компиляции. Неопределенная ситуация существует если 
список слов компиляции удален. 

Неопределенная ситуация существует, если Р0Р6ЕТ, удаляет слово, 
требуемое для правильного выполнения. 

Примечание: Это слово устаревшее и включено как уступка существующим 
реализациям. 

См.: 3.4.1 Синтаксический анализ. 

15.6.2.2250 ЗТАТЕ Т00Ц5 ЕХТ 

( -- а-асісіг ) 

Расширьте семантику 6.1.2250 ЗТАТЕ, чтобы позволить ;СООЕ, изменить 
значение в ЗТАТЕ. Программа непосредственно не должна изменять 
содержимое ЗТАТЕ. 

См.: 3.4 Интерпретатор текста РогбП, 6.1.0450 :, 6.1.0460 ;, 6.1.0670 
АБОРТ, 6.1.2050 СИЛТ, 6.1.2250 ЗТАТЕ, 6.1.2500 [, 6.1.2540 ], 
6.2.0455 :МОИАМЕ, 15.6.2.0470 ;СООЕ. 

15.6.2.2531 [ЕІ_5Е] "Ьгаскеб -еізе" Т00Б5 ЕХТ 

Компиляция: Исполняет семантику выполнения, данную ниже. 

Выполнение: ( "<зрасез>пате ... " -- ) 

Пропускает ведущие пробелы, выделяет и снимает ограниченные 
пробелом слова из области анализа, включая вложенные ссылки [ІР] 

... [ТНЕІМ] и [ІР] ... [ЕІ_5Е] ... [ТНЕІМ] , пока слово [ТНЕІМ] не будет 
проанализировано и снято. Если область анализа становится 
исчерпанной, она пополняется как с помощью РЕРІШ. [ЕІ_5Е] - слово 
немедленного исполнения. 

См.: 3.4.1 Синтаксический анализ. 

15.6.2.2532 [ІР] "Ьгаскеб-іТ" ТООбЗ ЕХТ 
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Компиляция: Исполняет семантику выполнения, данную ниже. 

Выполнение: ( Тіад | Тіад "<зрасез>пате ... " -- ) 

Если Тіад - Тгие, не делает ничего. Иначе, пропускает ведущие 
пробелы, выделяет и снимает ограниченные пробелом слова из области 



анализа, включая вложенные ссылки [ІР] . . . [ТНЕІМ] и [ІР] . . . [ЕІ_5Е] 
... [ТНЕІМ], пока слово [ЕІ_5Е] или слово [ТНЕІМ] не будет 
проанализировано и снято. Если область анализа становится 
исчерпанной, она пополняется как с помощью РЕРІШ. [ІР] - слово 
немедленного исполнения. 

Неопределенная ситуация существует, если [ІР] - следствие 
выполнения Р05ТР0ІМЕ, или если достигнут конец входного буфера и не 
может быть пополнен перед анализом ограничителей [ЕІ_5Е] или [ТНЕІМ] . 

15.6.2.2533 [ТНЕІМ] "Ьгаскеб-ббеп" Т00І.5 ЕХТ 

Компиляция: Исполняет семантику выполнения, данную ниже. 

Выполнение: ( -- ) 

Не делает ничего. [ТНЕІМ] - слово немедленного исполнения. 
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16. _ 

Дополнительный набор слов порядка поиска 

16.1 _ 

Введение 

16.2 _ 

Дополнительные термины и нотация 

Список слов компиляции: Список слов, в который помещаются новые имена 
определений. 

Порядок поиска: Список списков слов, определяющих порядок, в котором будет 
просмотрен словарь. 

16.3 _ 

Дополнительные условия применения 

16.3.1 _ 

Типы данных 

Идентификаторы списка слов - зависящие-от-реализации одна-ячейка значения, 
которые идентифицируют списки слов. 

Добавьте таблицу 16.1 к таблице 3.1. 


Таблица 16.1 - Типы данных 

Символ Тип данных Размер на стеке 


місі идентификатор списка слов 1 ячейка 


См.: 3.1 Типы данных, 3.4.2 Поиск имен определений, 3.4 Интерпретатор текста 
Рогбб. 

16.3.2 _ 

Запросы к окружению 

Добавьте таблицу 16.2 к таблице 3.5. 


См.: 3.2.6 Запросы к окружению. 





Таблица 16.2 - Строки запросов к окружению 


Строка 

Тип 

Константа Значение 


5ЕАРСН-0Р0ЕР 

Тіад 

по 

набор слов порядка поиска 

присутствует 

5ЕАРСН-ОРОЕР-ЕХТ 

Тіад 

по 

дополнительный набор слов 
присутствует 

порядка поиска 

М0Р01Л5Т5 

п 

уез 

максимальное число списков 

в порядке поиска 

слов используемых 


16.3.3 _ 

Поиск имен определений 

При просмотре списка слов для имени определения, система должна просматривать 
каждый список слов от его последнего определения до первого. Просмотр может 
охватывать только отдельный список слов, как с ЗЕАРСН-МОРРІЛЗТ, или все списки 
слов в порядке поиска, как в текстовом интерпретаторе и РІШ. 

134 


Изменение порядка поиска должно затрагивать только последующий поиск имен 
определений в словаре. 

Система с набором слов Порядка поиска должна позволять, по крайней мере, восемь 
списков слов в порядке поиска. 

Неопределенная ситуация существует, если программа изменяет список слов 
компиляции в течение компиляции определения или перед модификацией поведения 
последнего откомпилированного определения с помощью ;ССЮЕ, 00Е5>, или 
ІММЕРІАТЕ . 

Программа, которая требует больше чем восемь списков слов в порядке поиска, 
имеет зависимость от окружения. 

См.: 3.4.2 Поиск имен определений 

16.3.4 _ 

Непрерывные области 

Зоны области данных созданной операциями, описанными в 3.3.3.2 Непрерывные 
области, могут быть состоящими из нескольких несмежных участков, если Ы0Р0ІЛ5Т 
выполнимо в пределах распределений. 

16.4 _ 

Дополнительные документационные требования 

16.4.1 _ 

Системная документация 

16.4.1.1 _ 

Опции определенные реализацией 

- максимальное число списков слов в порядке поиска (16.3.3 Поиск имен 
определений, 16.6.1.2197 5ЕТ-0К0ЕР); 

- минимальный порядок поиска (16.6.1.2197 5ЕТ-0Р0ЕР, 16.6.2.1965 ОІ\ІІ_Ѵ) . 

16.4.1.2 _ 

Неопределенные ситуации 

- изменение списка слов компиляции (16.3.3 Поиск имен определений); 

- пустой порядок поиска (16.6.2.2Ѳ37 РРЕѴІ01І5); 

- слишком много списков слов в порядке поиска (16.6.2.0715 АІ_50) . 





16.4.1.3 


Другая системная документация 


- нет дополнительных требований. 

16.4.2 _ 

Программная документация 

16.4.2.1 _ 

Зависимости от окружения 

- требование больше чем восьми списков слов в порядке поиска (16.3.3 Поиск имен 
определений). 

16.4.2.2 _ 

Другая программная документация 

- нет дополнительных требований. 
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16.5 _ 

Соглашение и наименование 

16.5.1 _ 

А№ РогІИ системы 

Фраза "Предоставляет набор слов порядка поиска" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь набор слов 
порядка поиска. 

Фраза "Предоставляет имена из расширения набора слов порядка поиска" должна 
быть добавлена к наименованию любой Стандартной системы, которая предоставляет 
часть расширения набора слов порядка поиска. 

Фраза "Предоставляет расширение набора слов порядка поиска" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет весь 
набор слов порядка поиска и расширение набора слов порядка поиска. 

16.5.2 _ 

А№ РогІИ программы 

Фраза "Требуется набор слов порядка поиска" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
набор слов порядка поиска. 

Фраза "Требуются имена из расширения набора слов порядка поиска" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения набора слов порядка поиска. 

Фраза "Требуется расширение набора слов порядка поиска" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь набор слов порядка поиска и расширение набора слов порядка поиска. 

16.6 _ 

Словарь 

16.6.1 _ 

Слова порядка поиска 

16.6.1.1180 0ЕРІІМІТІ0М5 
( -- ) 


5ЕАВСН 



Делает список слов компиляции таким же, как первый список слов в 
порядке поиска. Определяет, что имена последующих определений будут 
помещены в список слов компиляции. Последующие изменения в порядке 
поиска не будут затрагивать список слов компиляции. 

См.: 16.3.3 Поиск имен определений. 

16.6.1.1550 РІШ 5ЕАПСН 

Расширьте семантику 6.1.1550 РІІ\Ю, таким образом: 

( с-асісіг -- с-асісіг 0 | хі 1 | хі -1 ) 

Ищет определение именованное в строке со счетчиком в с-асісіг. Если 
определение не найдено после поиска всех списков слов в порядке 
поиска, возвращает с-асісіг и нуль. Если определение найдено, 
возвращяет хі . 
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Если определение немедленного исполнения, также возвращает один 
(1); иначе также возвращает минус-один (-1). Для данной строки, 
значения возвращенные РІІ\Ю во время компиляции, могут отличаться от 
возвращенных при не компиляции. 


См.: 3.4.2 Поиск имен определений, 6.1.0070 ', 6.1.1550 РІІ\Ю, 6.1.2033 
Р05ТР0ІМЕ, 6.1.2510 ['], Ц . 6.7 Іштесііаіе - ности . 

16.6.1.1595 Р0КТН-М0К0ІЛ5Т 5ЕАРСН 

( -- МІСІ ) 

Возвращает місІ, идентификатор списка слов, который включает все 
стандартные слова, предоставленные реализацией. Этот список слов - 
первоначально список слов компиляции и - часть начального порядка 
поиска. 


16.6.1.1643 6ЕТ-СІІРРЕІМТ ЗЕАРСН 

( -- місІ ) 

Возвращает місІ, идентификатор списка слов компиляции. 

16.6.1.1647 6ЕТ-0Р0ЕР 5ЕАРСН 

( - - місіп . . . місіі п ) 

Возвращает число списков слов п в порядке поиска и идентификаторы 
списков слов місіп ... місіі идентифицирующие эти списки слов, місіі 
идентифицирует список слов, который просматривается первым, и місіп 
список слов, который просматривается последним. Порядок поиска не 
затронут. 

16.6.1.2192 5ЕАРСН -Ѵ\ЮР0І_І5Т 5ЕАКСН 

( с-асісіг и місІ - - 0 | хі 1 | хі -1 ) 

Ищет определение, идентифицированное строкой с-асісіг и в списке слов 
идентифицированном місІ. Если определение не найдено, возвращает 
нуль. Если определение найдено, возвращает его идентификатор 
исполнения хі и один (1) если определение немедленного исполнения, 
и минус-один (-1) иначе. 


16.6.1.2195 5ЕТ-СІІРРЕІМТ 5ЕАПСН 

( місІ -- ) 

Устанавливает список слов компиляции на список слов, 
идентифицированный місІ. 


16.6.1.2197 ЗЕТ-0Р0ЕП 5ЕАРСН 

( місіп . . . місіі п - - ) 

Устанавливает порядок поиска на список слов, идентифицированный 
місіп . . . місіі. Впоследствии, список слов місіі будет просматриваться 
первым, и список слов місіп просматриваться последним. Если п 
нулевой, порядок поиска пуст. Если п - минус один, установит 



порядок поиска на определенный реализацией минимальный порядок 
поиска. Минимальный порядок поиска должен включать слова РОРТН- 
ЫОРОІЛЗТ и 5ЕТ-0Р0ЕР. Система должна позволять быть п по крайней 
мере восьми. 

16.6.1.2460 Ы0РРІЛ5Т ЗЕАРСН 

( -- МІСІ ) 

Создает новый пустой список слов, возвращая его идентификатор 
списка слов місІ . Новый список слов может быть возвращен из пула 
предварительно размещенных списков слов или может быть динамически 
распределен в области данных. Система должна позволять создание, по 
крайней мере, 8 новых списков слов в дополнение к любым 
предоставленным как часть системы. 
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16.6.2 _ 

Расширения слов порядка поиска 


16.6.2.0715 А1_50 ЗЕАРСН ЕХТ 

( -- ) 

Преобразует порядок поиска, состоящий из місіп, ... місІ2, місіі (где 
місіі просматривается первым) в місіп, ... місІ2, місіі, місіі. 
Неопределенная ситуация существует, если есть слишком много списков 
слов в порядке поиска. 


16.6.2.1590 РОРТН 
( -- ) 

Преобразует порядок поиска, состоящий из 
місіі просматривается первым) в місіп, . . . 


ЗЕАРСН ЕХТ 

місіп, ... місІ2, місіі (где 
МІСІ2, місІРОРТН-Іл/ОРОІЛЗТ. 


16.6.2.1965 ОМІ.Ѵ ЗЕАРСН ЕХТ 

( -- ) 

Устанавливает порядок поиска на определенный реализацией 
минимальный порядок поиска. Минимальный порядок поиска должен 
включать слова РОРТН -МОРРІЛЗТ и ЗЕТ-ОРРЕР. 


16.6.2.1985 ОРРЕР ЗЕАРСН ЕХТ 

( -- ) 

Отображает списки слов в порядке поиска в их последовательности 
порядка поиска, от первого просматриваемого до последнего. Также 
отображает список слов, в который будут помещены новые определения. 
Формат отображения - зависящий от реализации. 

ОРРЕР может быть реализован с использованием слов вывода 
отображаемых чисел. Следовательно, их использование может разрушать 
временную область, идентифицированную #>. 

См.: 3.3.3.6 Другие временные области. 

16.6.2.2037 РРЕѴІ01І5 ЗЕАРСН ЕХТ 

( -- ) 

Преобразует порядок поиска, состоящий из місіп, ... місІ2, місіі (где 
місіі просматривается первым) в місіп, ... місІ2. Неопределенная 
ситуация существует, если порядок поиска был пуст прежде, чем было 
выполнено РРЕѴІ01І5 . 
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17 . 


Дополнительный строковый набор слов 



17.1 _ 

Введение 

17.2 _ 

Дополнительные термины и нотация 

Нет. 

17.3 _ 

Дополнительные условия применения 

Добавьте таблицу 17.1 к таблице 3.5. 

См.: 3.2.6 Запросы к окружению. 


Таблица 17.1 - Строки запросов к окружению 

Строка Тип Константа Значение 


ЗТКІМ6 "Лад по строковый набор слов присутствует 

5ТКІМ6-ЕХТ "Лад по дополнительный строковый набор слов 

присутствует 


17.4 _ 

Дополнительные документационные требования 


Нет. 

17.5 _ 

Соглашение и наименование 

17.5.1 _ 

А№ РогІН программы 

Фраза "Предоставляет строковый набор слов" должна быть добавлена к наименованию 
любой Стандартной системы, которая предоставляет весь строковый набор слов. 

Фраза "Предоставляет имена из расширения строкового набора слов" должна быть 
добавлена к наименованию любой Стандартной системы, которая предоставляет часть 
расширения строкового набора слов. 

Фраза "Предоставляет расширение строкового набора слов" должна быть добавлена к 
наименованию любой Стандартной системы, которая предоставляет весь строковый 
набор слов и расширение строкового набора слов. 

17.5.2 _ 

А№ РогІП программы 

Фраза "Требуется строковый набор слов" должна быть добавлена к наименованию 
Стандартной программы, которая требует, чтобы система предоставила строковый 
набор слов. 

Фраза "Требуются имена из расширения строкового набора слов" должна быть 
добавлена к наименованию Стандартной программы, которая требует, чтобы система 
предоставила часть расширения строкового набора слов. 

Фраза "Требуется расширение строкового набора слов" должна быть добавлена к 
наименованию Стандартной программы, которая требует, чтобы система предоставила 
весь строковый набор слов и расширение строкового набора слов. 
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17.6 


Словарь 


17.6.1 _ 

Строковые слова 

17.6.1.0170 -ТКАІІ.ІМ6 "сіази-ігаіііпд" 5ТРІМ6 

( с-асісіг иі -- с-асісіг и2 ) 

Если иі больше чем нуль, и2 равно иі минус число пробелов в конце 
символьной строки, определенной с-асісіг иі. Если иі нуль или вся 
строка состоит из пробелов, и2 нулевой. 

17.6.1.0245 /5ТРІМ6 "зіазіл-зігіпд" 5ТРІМ6 

( с-асісігі иі п -- с-абсІг2 и2 ) 

Корректирует символьную строку с-асісігі, п символами. Результирующая 
символьная строка, определенная с-абсІг2 и2, начинается с с-асісігі 
плюс п символов, и длиной иі минус п символов. 

17.6.1.0780 В1.АМК 5ТРІМ6 

( с-асісіг и -- ) 

Если и больше чем нуль, сохраняет символьное значение пробела в и 
последовательных символьных позициях, начинающихся с с-асісіг. 

17.6.1.0910 СМОѴЕ "с-шоѵе" 5ТРІМ6 

( с-асісігі с-абсІг2 и -- ) 

Если и больше чем нуль, копирует и последовательных символов из 
области данных начинающейся с с-асісігі в область, начинающуюся с с- 
абсІг2, выполняя посимвольно с наименьших адресов к наибольшим. 

Отличие с: 17.6.1.0920 СМОѴЕ> . 

17.6.1.0920 СМОѴЕ> "с-шоѵе-ир" 5ТРІМ6 

( с-асісігі с-абсІг2 и -- ) 

Если и больше чем нуль, копирует и последовательных символов из 
области данных начинающейся с с-асісігі в область, начинающуюся с с- 
абсІг2, выполняя посимвольно с наибольших адресов к наименьшим. 

Отличие с: 17.6.1.0910 СМОѴЕ. 

17.6.1.0935 СОМРАРЕ 5ТРІМ6 

( с-асісігі иі с-асісІг2 и2 -- п ) 

Сравнивает строку, определенную с-асісігі иі со строкой, определенной 
с-абсІг2 и2. Строки сравниваются, начиная с заданных адресов, 
посимвольно, до длины более короткой строки или до нахождения 
различия. Если две строки идентичны - п нулевое. Если две строки 
идентичны до длины более короткой строки, п равно минус-один (-1) 
если иі - меньше чем и2, иначе один (1). Если две строки - не 
идентичны до длины более короткой строки, п равно минус-один (-1) 
если первый несоответствующий символ в строке определенной с-асісігі 
иі имеет меньшее числовое значение чем соответствующий символ в 
строке, определенной с-абсІг2 и2, иначе один (1). 
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17.6.1.2191 5ЕАРСН 5ТРІМ6 

( с-асісігі иі с-асісІг2 и2 -- с-абсІгЗ иЗ біад ) 

Ищет строку, определенную с-асісігі иі в строке, определенной с-абсІг2 
и2. Если біад - Ігие, соответствие было найдено с с-абсІгЗ и с иЗ 
оставшимися символами. Если біад - баізе не было никакого 
соответствия и с-абсІгЗ равен с-асісігі, и иЗ равно иі. 


17.6.1.2212 5І_ІТЕРАІ_ 


ЗТРІМ6 



Интерпретация: Семантика интерпретации для этого слова не определена. 


Компиляция: ( с-асісігі и -- ) 

Добавляет семантику времени-выполнения, данную ниже к текущему 
определению. 

Время-выполнения: ( -- с-асІсІг2 и ) 

Возвращает с-асІсІг2 и описание строки, состоящей из символов 
определенных с-асісігі и в течение компиляции. Программа не должна 
изменять возвращенную строку. 


17.6.2 _ 

Расширения строковых слов 

Нет 
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А. _ 

Разъяснения (информационное приложение) 

А. 1 _ 

Введение 

А.1.1 _ 

Цель 

А.1.2 _ 

Назначение 

Этот Стандарт более обширен, чем предыдущие промышленные стандарты для языка 
РогШ. Несколько факторов сделали это необходимым: 

- желание разрешить конфликты между предыдущими стандартами; 

- потребность устранить семантические двусмысленности и другие несоответствия; 

- требование стандартизировать обычную практику, где возможно разрешение 
расхождений способом, который минимизирует стоимость соглашения; 

- желание стандартизировать общие системные методы, включая соответствующие 
аппаратным средствам. 

Результат усилий удовлетворения всех этих требований - Стандарт устроенный так, 
чтобы требуемый набор слов остался маленьким. Таким образом, А№ РогбП может 
быть предоставлен для ресурсо-ограниченных встраиваемых систем. Слова вне 
требуемого набора слов организованы во множество дополнительных наборов слов и 
их расширений, допуская реализацию адаптированных систем, которые являются 
Стандартными. 

При оценке относительных достоинств, члены ХЗЛ14 Технического Комитета 
руководствовались следующими целями (перечисленными в алфавитном порядке): 

Последовательность 

Стандарт предоставляет функционально законченный набор слов с минимальным 
функциональным перекрытием. 

Стоимость соглашения 

Эта цель включает такие проблемы как обычная практика, сколько существующего 
кода было бы сломано предложенным изменением, и количество усилий требуемых для 
приведения существующих приложений и систем в соответствие со Стандартом. 

Эффективность 

Скорость выполнения, компактность памяти. 



Переносимость 

Слова, выбранные для включения должны быть свободны от зависящих от системы 
функций . 

Удобочитаемость 

Имена определений Рогбб должны ясно очерчивать их поведение. Это поведение 
должно иметь очевидную простоту, которая обеспечивает быстрое понимание. Рогбб 
должен быть легко познаваем, и обеспечивать легко поддерживаемый код. 

Полезность 

Считается, имеет достаточно существенные функциональные возможности и частоту 
использования, чтобы считать подходящим для включения. 
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А.1.3 _ 

Организация Документа 

А.1.3.1 _ 

Наборы слов 

С начала, ХЗЛ4 Технический Комитет столкнулся не только с противоречивыми 
идеями относительно того каким является "реальный" Рогбб, но также и 
противоречивыми потребностями различных групп в пределах Рогіб сообщества. В 
одной крайности были те, кто требовали "пустого" Рогіб. В другой крайности были 
те, кто хотели "жирного" Рогбб. Многие были где-то по середине. Все были 
убеждены в справедливости их собственной позиции и не правильности, по крайней 
мере, одной из этих двух крайностей. Состав комитета отразил этот полный 
диапазон интересов. 

Подход, который мы приняли, состоит в определении Основного набора слов 
устанавливающего самый нижний предел требуемой системной функциональности, и 
предоставлении портфеля дополнительных наборов слов для специальных целей. Этот 
простой подход соответствует фундаментальной природе Рогбб как расширяемого 
языка, и таким образом достигает своего рода мета-расширяемости. 

В этом ключе, высокоуровневый компромисс, независимо от фактического состава 
индивидуального набора слов, на долгий срок установлена твердая и реальная 
структура. Могут соглашаться или не соглашаться, что должен быть набор слов 
І_оса1з, или что слово СОМРШЕ, принадлежит расширению основного набора слов. 

Но, по крайней мере, есть механизм посредством которого такие вещи могут быть 
включены логичным и организованным способом. 

Важно несколько следствий этой схемы дополнительных наборов слов. 

Первое, А№ Рогіб системы могут по-прежнему быть реализованы на большем 
диапазоне аппаратных средств, чем может быть заявлено почти любым другим 
отдельным языком. Так как требуется только Основной набор слов, даже очень 
ограниченные аппаратные средства будут способны вмещать АМЗ РогИп реализацию. 

Второе, ожидается большая степень переносимости приложений, и программистов. 
Дополнительные наборы слов стандартизируют различные функции (например, с 
плавающей точкой), это было широко реализовано прежде, но не с однородными 
именами определений и методологий, ни с равными уровнями полноты. С такими 
словами, теперь стандартизированными в дополнительные наборы слов, связь между 
программистами - устно, через журнал или газетные статьи, и т.д. - прыгнут к 
новому уровню возможностей, и совместноиспользуемость кода и приложений должна 
повыситься впечатляюще. 

Третье, А№ Рогіб системы могут быть разработаны, чтобы предложить пользователю 
возможность выборочно, даже динамически, включать или исключать один или 
большее количество дополнительных наборов слов или их частей. Также, более 
дешевые изделия могут быть предложены пользователю, который нуждается в 



Основном наборе слов и не более. Таким образом, пользователю будет доступна 
фактически неограниченная гибкость. 


Но эти преимущества имеют цену. Бремя находится на пользователе, чтобы решить 
какие свойства желательны, и соответственно выбирать предложенные изделия, 
особенно когда важна переносимость приложения. Мы не ожидаем от большинства 
разработчиков попыток предоставлять все наборы слов, а скорее выбирать наиболее 
ценные для их рыночного предназначения. 

Основное требование - это, если разработчик утверждает что имеет частичный 
дополнительный набор слов, должна быть доступна полная требуемая часть этого 
набора слов. Если разработчик желает предложить только часть дополнительного 
набора слов, приемлемо говорить, например "Эта система предлагает части 
[названного] набора слов", особенно если выбранные или исключенные слова 
перечислены ясно. 
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Каждый дополнительный набор слов будет вероятно апеллировать к специфической 
клиентуре. Например, ученые, выполняющие сложные математические анализы могут 
возлагать большее значение на набор слов с плавающей точкой, чем программисты 
разрабатывающие простые внедряемые контроллеры. Как в случае основных 
расширений мы ожидаем, что разработчики предложат те наборы слов, которые по их 
мнению будут оценены их пользователями. 

Дополнительные наборы слов можно предлагать в исходной форме или иначе 
факторизованными так, чтобы пользователь мог выборочно их загружать. 

Расширения к дополнительным наборам слов включают слова, которые считаются 
менее обязательными для выполнения основной деятельности поддерживаемой набором 
слов, хотя, несомненно, для этого уместны. Как в случае основных расширений, 
разработчики могут выборочно добавлять описанные подмножества расширения набора 
слов, предусматривая наименование не вводящее в заблуждение пользователя 
относительно мысли, что все слова присутствуют. 

А. 2 _ 

Термины и нотация 

А.2.1 _ 

Определения терминов 

неопределенная ситуация 

Реакция Стандартной системы на неопределенную ситуацию оставлена на усмотрение 
разработчика. Стандартная система не нуждается в явном обнаружении или 
сообщении о случаях неопределенных ситуаций. 

кросс компилятор 

Кросс компиляторы могут использоваться для подготовки программы к выполнению во 
внедренной системе, или могут использоваться для генерации ядра РогИп для той 
же самой или другой среды времени-выполнения. 

поле данных 

В более ранних стандартах, поля данных были известны как "поля параметров". 

В Рогбб системах с подпрограммным шитым кодом, все - объектный код. Нет 
традиционных полей кода или данных. Только слово, определенное с помощью СРЕАТЕ 
или словом, которое вызывает СРЕАТЕ, имеет поле данных. Только поле данных, 
определенное через СРЕАТЕ, может обрабатываться переносимо. 

набор слов 

Этот Стандарт признает, что некоторые функции, хотя и полезны в некоторых 
прикладных областях, не достаточно общие, чтобы оправдывать требование их во 
всех системах РогІИ. Но они являются полезными для группирования слов РогІИ по 



родственным функциям. Эти вопросы имеют дело с использованием концепции наборов 
слов. 

"Основной" набор слов содержит неотъемлемое тело слов в РогііИ системе. Только 
этот - "требуемый" набор слов. Другие наборы слов определенные в этом Стандарте 
- это необязательные добавления делающие возможным предоставление Стандартной 
системы с приспособленными уровнями функциональности. 

А.2.2 _ 

Нотация 
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А.2.2.2 _ 

Стековая нотация 

Использование -зуз, огід, и сіезі; типов данных в диаграммах стекового эффекта 
передает две части информации. Первое, это предупреждает читателя, что много 
реализаций используют стек данных не установленным способом для их целей, так 
что элементы ниже стеков потока управления или данных являются недоступными. 
Второе, в случаях, где используются огід и сіезі, документированы явные правила 
спаривания при допущении, что все системы осуществят такую модель, чтобы ее 
результат был эквивалентен применению некоторого стека, и фактически многие 
реализации используют стек данных для этой цели. Однако ничто в этом Стандарте 
не требует, чтобы реализации фактически использовали стек данных (или любой 
другой) для этой цели, при условии, что поддержано подразумеваемое поведение 
модели. 

А. 3 _ 

Условия применения 

Системы Рогііі необычно просты для развития, по сравнению с компиляторами для 
более традиционных языков типа С. В дополнение к системам Рогііі, поддерживаемым 
производителями, общедоступные реализации и руководства по реализации были 
широко доступны почти двадцать лет, и большое количество людей разработали их 
собственные Рогііі системы. В результате, сформировалось разнообразие подходов 
реализации, каждый оптимизированный для специфической платформы или конкретного 
рынка. 

ХЗЛ4 Технический Комитет пытался приспособить это разнообразие, сдерживая 
разработчиков так мало насколько это возможно, совместимо с целью определения 
стандартного интерфейса между основной Системой Рогііі и прикладной программой, 
разрабатываемой на нем. 

Так же мы не будем ручаться, в этом разделе сообщать Вам, как реализовать Рогііі 
систему, а скорее предусмотреть некоторое руководство относительно того, какие 
минимальные требования имеются для системы, которая может должным образом 
претендовать на соответствие этому Стандарту. 

А.3.1 Типы данных 

Большинство компьютеров имеет дело с произвольными наборами двоичных разрядов. 
Нет никакого способа установить контроль, содержит ли ячейка адрес или целое 
число без знака. Единственное значение, которым данная величина обладает - это 
значение, назначенное приложением. 

Когда данные используются, значение результата зависит от значения, 
назначенного для входных величин. Некоторые комбинации входных значений 
производят бессмысленный результат: например, какое значение может быть 
назначено для арифметической суммы АЗСІІ представления символа "А" и ТГСІІЕ 
флага? Ответ может быть "никакое значение"; или альтернативно, эта операция 
могла бы быть первым шагом в создании контрольной суммы. Контекст - 
определяющий. 



Порядок ограничения значений, которые программа может назначить различным 
комбинациям наборов двоичных разрядов - иногда называется типизация данных. 
Много машинных языков устанавливают явную типизацию данных, и имеются 
компиляторы, которые предотвращают неточные операции. 

РогИп редко явно налагает ограничения типа данных. Однако типы данных неявно 
существуют, и требуется дисциплина, особенно если переносимость программ - 
цель. В РогТІі, возложено на программиста (скорее чем на компилятор) определение 
того, что данные точно типизированы. 

Этот раздел пытается предлагать руководство относительно фактической типизации 
данных в РогІІі. 
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А.3.1.2 _ 

Символьные типы 

РогІП не принуждает к применению типа данных посредством глубины стека, для 
правильной идентификации и надлежащей манипуляции символьным типом данных. 
Символы не обязательно занимают значимыми данными всю ширину их единственного 
элемента стека. В то время как различие между знаковым и без знаковым символом 
полностью отсутствует в формальной спецификации РогІІі, практическая тенденция 
состоит в том, чтобы рассматривать символы как короткие положительные целые 
числа, когда входят в силу математические операции. 

а) Стандартный набор символов 

1) Элемент памяти для символьного типа данных (С@, С!, РІІ_І_, и т.д.) должен 
быть способен содержать числа без знака от 0 до 255. 

2) Реализация не требует ограничения символьной памяти этим диапазоном, но 
стандартная программа без зависимостей от окружения не должна быть способна 
сохранять числа вне этого диапазона в "сііаг" адресе ячейки. 

3) Разрешенные представления чисел - дополнительный код (дополнение до двух), 
обратный код (дополнение до единицы), и знаковая величина. Заметьте, что все 
эти системы счисления сходятся в представлении положительных чисел. 

4) Так как "сПаг" может хранить маленькие положительные числа и так как 
символьный тип данных - это под диапазон типа данных целого числа без знака, С! 
должен хранить п младших бит ячейки (8 <= п <= биты/ячейка). Учитывая диапазон 
допустимых представлений числа и их известное кодирование, "ТРІІЕ хх С! хх С@" 
должно оставить элемент стека с некоторым набором битов, который будет принят 
словом ІР как ненулевой. 

5) Для целей ввода (КЕУ, АССЕРТ, и т.д.) и вывода (ЕМІТ, ТУРЕ, и т.д.), 
кодирование между числами и удобочитаемыми символами - это І50646/ІРѴ (А5СІІ) в 
пределах диапазона от 32 до 126 (пробел в ~). ЕВСЭЮ - исключен (большинство 
компьютерных систем "ЕВСОІС" также поддерживает А5СІІ). Вне этого диапазона, 
это - на уровне реализации. Очевидный выбор реализации это использовать 
управляющие символы АЗСІІ для диапазона от Ѳ до 31, по крайней мере, для 
"отображаемых" символов в этом диапазоне (ТАВ, РЕТІІРІМ, ІЛМЕРЕЕО, РОРМРЕЕО) . 
Однако это - не столь же ясно, как это может казаться, из-за различий между 
операционными системами в трактовке этих символов. Например, в некоторых 
системах ТАВ по 4 символьным границам, в других по 8 символьным границам, и в 
иных по предварительно устанавливаемым табуляторам. Некоторые системы исполняют 
автоматический перевод строки после перевода каретки, другие исполняют 
автоматический перевод каретки после перевода строки, и другие не делают ни 
чего. 


Коды от 128 до 255 могут, в конечном счете, быть стандартизированы формально 



или неформально для использования как интернациональных символов, типа символов 
с диакритическими знаками, находимых во многих Европейских языках. Одно такое 
кодирование - 8-Ы1: 150 І_а1:іп-1 набор символов. Компьютерный рынок в целом, в 
конечном счете, решит, какой набор кодирования этих символов будет преобладать. 
Для реализаций Рогбй выполняющихся под операционной системой (большинство их 
выполняется на стандартных платформах этих дней), большинство разработчиков 
Рогбб будет вероятно делать выбор не зависимо от того что делает система, без 
выполнения какого либо перекодирования в пределах самой системы Рогбб. 
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6) Стандартная программа может зависеть от способности получать любой символ в 
диапазоне 32 ... 126 посредством КЕУ, и подобно отображать тот же самый набор 
символов с помощью ЕМІТ . Если программа должна мочь получать или отображать 
любой специфический символ вне этого диапазона, она может объявить зависимость 
от окружения на способность получать или отображать этот символ. 

7) Стандартная программа не может использовать управляющие символы в именах 
определений. Однако Стандартная система не требует устанавливать это 
запрещение. Таким образом, существующие системы, которые в настоящее время 
позволяют управляющие символы в именах слов из В1_0СК источника, могут 
продолжать позволять их, и программы, выполняющиеся на этих системах, продолжат 
работать. В источнике текстового файла, действие синтаксического анализа с 
пробелом как разделителем (например, ВЦ МОРР) обрабатывает управляющие символы 
так же как пробелы. Это эффективно подразумевает, что Вы не можете использовать 
управляющие символы в именах определений из источника текстового файла, так как 
текстовый интерпретатор обработает управляющие символы как разделители. 
Заметьте, что это "сворачивание управляющего символа" применяется только когда 
разделитель пробел, таким образом фраза "СНАР ) МОРР" может забирать строку 
содержащую управляющие символы. 

b) Хранение и поиск 

Символы передаются со стека данных в память с помощью С! и из памяти на стек 
данных с помощью С§. Число младших значащих бит эквивалентное звисящей-от- 
реализации ширине символа передается из вытолкнутого элемента стека данных в 
адрес выполнением С! без воздействия на любые биты в адресе назначения, которые 
могут включать старшую значащую часть ячейки; однако действие С@ очищает все 
биты старшей значащей части элемента стека данных, который оно туда помещает - 
вне зависящей-от-реализациой ширины символа (который может включать информацию 
дисплея определенную реализацией в битах старшей значащей части). Программист 
должен иметь в виду, что использование с произвольными элементами стека слов 
предназначенных для символьного типа данных может приводить к усечению таких 
данных. 

c) Манипуляции на стеке 

В дополнение к С@ и С!, символы перемещаются на стек, из стека и на стеке 
данных следующими словами: 

>Р 7РІІР РРОР РІІР ОѴЕР РІСК Р> Р§ Р0І_І_ РОТ 5\л/АР 
б) Дополнительные операции 

Следующие математические операторы допустимы для символьных данных: 

+ - * / /М00 МСЮ 

Следующие сравнения и поразрядные операторы могут быть допустимы для символов, 
имеющих в виду, что отображаемая информация, кэшируемая в самых старших битах 
символов определенным реализацией способом, может быть замаскирована или иначе 
имеет дело с: 



АІ\Ю ОР > < ІІ> ІІ< 


о 0= Ѳ<> МАХ МІІ\І 


І_5НІРТ Р5НІРТ 
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А.3.1.3 _ 

Типы одна-ячейка 

Элемент стека одна-ячейка, рассматриваемый без отношения к типизации - 
фундаментальный тип данных РогІИ. Все другие типы данных фактически 
представлены одним или более элементами стека одна-ячейка. 

a) Хранение и поиск 

Данные одна-ячейка передаются со стека в память посредством !; из памяти на 
стек посредством Все биты передаются в обоих направлениях, и никакой 
контроль соответствия типов любой разновидности не выполняется; также 
Стандартная система не проверяет что адрес памяти, используемый ! или @ должным 
образом выровнен или имеет должный размер для размещения данной величины, таким 
способом передаваемой. 

b) Манипуляции на стеке 

Вот выбор наиболее важных слов, которые перемещают данные одна-ячейка на стек, 
из стека и на стеке данных: 

! § >Р 701ІР ОРОР ОІІР ОѴЕР РІСК Р> Р@ РОЩ РОТ 5\л/АР 

c) Операторы сравнения 

Следующие операторы сравнения универсально допустимы для одной или более одна- 
ячеек : 


= <> о= о<> 


А.3.1.3.1 _ 

Флаги 

РАЦ5Е флаг - величина данных одна-ячейка со всеми сброшенными битами, и ТРІІЕ 
флаг - величина данных одна-ячейка со всеми установленными битами. Там где 
слова РогИ'і, которые проверяют флаги, принимают любой ненулевой битовый образец 
как Іше, там существует понятие правильно построенного флага. Если операция, 
чей результат должен использоваться как флаг, может производить любую битовую 
маску иную, чем ТРІІЕ или РАІ_5Е, рекомендуемый порядок состоит в преобразовании 
результата к правильно построенному флагу посредством слова РогШ Ѳ<> так, 
чтобы результат любых последующих логических операций на флаге был 
предсказуемый. 

В дополнение к словам, которые перемещают, выбирают и сохраняют элементы одна- 
ячейка, следующие слова допустимы для операций на одном или более флаговых 
данных, находящихся на стеке данных: 

АІ\Ш 0Р ХОР ІІМѴЕРТ 

А.3.1.3.2 _ 

Целые числа 

Величина данных одна-ячейка может быть обработана Стандартной программой как 
целое число со знаком. Перемещение и сохранение таких данных выполняется как 
для любых данных одна-ячейка. В дополнение к универсально применимым операторам 
для данных одна-ячейка, определенным выше, следующие математические и операторы 
сравнения допустимы для целых чисел со знаком одна-ячейка: 



/ 1+ 1- АВ5 МАХ МІМ 


* */ ѴМСЮ /МОЭ МСЮ + +! - 

МЕОАТЕ 0< 0> < > 
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Учитывая одно и то же число битов, целые числа без знака обычно представляют 
вдвое большую величину абсолютного значения, представимую целыми числами со 
знаком . 

Величина данных одна-ячейка может быть обработана Стандартной программой как 
целое число без знака. Перемещение и сохранение таких данных выполняется как 
для любых данных одна-ячейка. Кроме того, следующие математические и операторы 
сравнения допустимы для целых чисел без знака одна-ячейка: 

им* цм/моо + +! - і+ 1- * и< и> 

А.3.1.3.3 _ 

Адреса 

Адрес уникально представлен как число без знака одна-ячейка и может быть 
обработан как такой когда перемещается на стек, из стека или на стеке. И 
наоборот, каждое число без знака представляет уникальный адрес (который - не 
обязательно адрес доступной памяти). Это один к одному отношение между адресами 
и числами без знака устанавливает эквивалентность между адресной арифметикой и 
соответствующими операциями на числах без знака. 

Несколько операторов предусмотрено специально для адресной арифметики: 

СНАР+ СНАР5 СЕШ+ СЕІ_І_5 

и, если набор слов с плавающей точкой присутствует: 

Р1_0АТ+ РІ_0АТ5 5РІ_0АТ+ 5РІ_0АТ5 0Р1_0АТ+ 0РЦ0АТЗ 

Стандартная программа может никогда не предполагать специфическое соответствие 
между адресом Рогій и физическим адресом, на который он отображен. 

А.3.1.3.4 _ 

Строки со счетчиком 

Тенденция в А№ Рогій должна переместиться к непротиворечивому использованию 
"с-асісіг и" представления строк на стеке. Использование альтернативного 
представления стека "адрес строки со счетчиком" не одобряется. Традиционные 
слова Рогій МОРО и РІШ продолжают использовать представление "адрес строки со 
счетчиком" по историческим причинам. Новое слово С", добавленное как помощь 
перенесения для существующих программ, также использует представление строки со 
счетчиком. 

Строки со счетчиком остаются полезными как способ сохранить строки в памяти. 

Это использование - не запрещается, но когда ссылки к таким строкам появляются 
на стеке, предпочтительно использовать "с-асісіг и" представление. 

А.3.1.3.5 _ 

Идентификаторы исполнения 

Ассоциация между идентификатором исполнения и определением статическая. Однажды 
сделанная, она не изменяется с изменениями в порядке поиска или чем-нибудь еще. 
Однако она не может быть уникальна, например, фразы 


и 


1 + 



СНАР+ 


могут возвращать одно и то же значение. 
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3.1.4 _ 

Типы пара-ячеек 

a) Хранение и поиск 

Чтобы выбирать и сохранять пары-ячеек, предусмотрены два оператора: 

2 @ 2 ! 

b) Манипуляции на стеке 

Дополнительно, эти операторы могут использоваться для перемещения пары-ячеек из 
стека, на стек и на стеке: 

2>Р 2РК0Р 2РІІР 20ѴЕР 2Р> 23\л/АР 2Р0Т 

c) Сравнение 

Следующие операции сравнения универсально допустимы для пары-ячеек: 

Р= РѲ= 

А.3.1.4.1 _ 

Целые числа две-ячейки 

Если целое число две-ячейки должно быть обработано как знаковое, допустимы 
следующие операции сравнения и математические операции: 

Р+ О- Р< РѲ< РАВЗ РМАХ РМІМ РМЕ6АТЕ М*/ М+ 

Если целое число две-ячейки должно быть обработано как без знаковое, допустимы 
следующие операции сравнения и математические операции: 

Р+ Р- ЦМ/МОР РІІ< 

А.3.1.4.2 _ 

Символьные строки 

См.: 3.1.3.4 Строки со счетчиком. 

А.3.2 _ 

Среда Реализации 

А.3.2.1 _ 

Числа 

Традиционно, РогбИ был реализован на машинах с дополнительным кодом (дополнение 
до двух), где есть взаимно-однозначное соответствие чисел со знаком и чисел без 
знака - любой элемент одна-ячейка может рассматриваться или как знаковое или 
без знаковое число. Действительно, знаковое представление любого положительного 
числа идентично эквивалентному представлению без знака. Далее, адреса 
обрабатываются как числа без знака: нет никакого отдельного указателя типа. 
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Арифметика, предписываемая на машинах с дополнительным кодом позволяет 



выполнять + и - со знаковыми и без знаковыми числами. Это арифметическое 
поведение глубоко внедрено в обычную практику РогІІі. Как следствие этих 
поведений, возможные диапазоны знаковых и без знаковых чисел, для реализаций 
базирующихся на каждой из допустимых арифметических архитектур, таковы: 


Арифметическая архитектура 

Числа со знаком 

Числа без знака 

Дополнительный код 

-п-1 Іо п 

Ѳ Іо 2п+1 

Обратный код 

-п Іо п 

О 

г+ 

О 

Величина со знаком 

-п Іо п 

О 

г+ 

О 


где п - самое большое положительное число со знаком. Для всех трех архитектур, 
знаковые числа в диапазоне от Ѳ до п поразрядно идентичны соответствующим 
числам без знака. Заметьте, что числа без знака на машине с арифметикой 
величины со знаком эквивалентны знаковым не отрицательным числам как следствие 
необходимого соответствия между адресами и числами без знака и требуемым 
поведением + и -. 

Для ссылок, эти представления чисел могут быть определены способом, в котором 
применено МЕ6АТЕ: 

Дополнительный код: : МЕ6АТЕ ІІМѴЕКТ 1+ ; 

Обратный код: : МЕ6АТЕ ІМѴЕРТ ; 

Величина со знаком: : МЕ6АТЕ НІ6Н-ВІТ ХОР ; 

где НІ6Н-ВІТ - битовая маска только на самый старший бит. Заметьте, что все эти 
системы счисления соглашаются в представлении неотрицательных чисел. 

Посредством 3.2.1.1 Внутреннее представление числа и 6.1.0270 Ѳ=, разработчик 
должен гарантировать, что никакое стандартное или поддерживаемое слово не 
возвращает отрицательный нуль для любого числового (не булевого или флагового) 
результата. Иначе будет нарушено много существующих программистских допущений. 

Не требуется реализовывать ни круговую без знаковую арифметику, ни 
устанавливать диапазон чисел без знака на полный размер ячейки. Есть 
исторический прецедент для ограничения диапазона и величиной +п, который 
является допустимым, когда размер ячейки больше 16 бит. 

А.3.2.1.2 _ 

Преобразование цифр 

Например, реализация могла бы преобразовывать символы с "а" по "г" тождественно 
в символы с "А" по "2", или она могла бы обрабатывать символы с " [ " по 
как дополнительные цифры с десятичной величиной с 36 по 71, соответственно. 

А.3.2.2 _ 

Арифметика 

А.3.2.2.1 _ 

Целочисленное деление 

РогІІі-79 Стандарт определяет что знаковые операторы деления (/, /МОР, МОР, 
*/М0Р, и */) округляют частные нецелого числа к нулю (симметричное деление). 
РогИп 83 изменяет семантику этих операторов на округление к отрицательной 
бесконечности (минимальное деление) . 
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Некоторые в семействе РогІП отказались преобразовывать системы и приложения из 
РогІІі-79 деления в РогІІі-83 деление. Чтобы разрешить эту проблему, А№ РогбИ 
системе разрешается поставлять или минимальные или симметричные операторы. 







Кроме того, А№ РогІП системы должны предоставлять примитив минимального 
деления (РМ/МСЮ), примитив симметричного деления (5М/ПЕМ), и оператор умножения 
смешанной точности (М*). 

Этот компромисс защищает инвестиции, сделанные в текущие приложения РогІІі; 
Рог1;Іі-79 и РогІИ-вЗ программы автоматически совместимы с А№ Рогіііі относительно 
деления. На практике, направление округления редко имеет значение для 
приложений. Однако если программа требует специфического направления 
округления, она может использовать примитив минимального деления РМ/МОО или 
примитив симметричного деления 5М/ПЕМ, для создания оператора деления 
желательной разновидности. Эта простая методика может использоваться для 
преобразования РогІІі-79 и Рогіііл -83 программ в А№ РогИл, без какого либо 
анализа исходных программ. 

А.3.2.2.2 _ 

Другие целочисленные операции 

Происходит ли антипереполнение, зависит от типа данных результата. Например, 
фраза 1 2 - дает антипереполнение, если результат без знака и производит 
допустимый знаковый результат -1. 

А.3.2.3 _ 

Стеки 

Единственный тип данных в РогСИ, который скорее имеется реально, чем существует 
абстрактно - это вход стека. Даже эта примитивная типизация РогСП 
предписывается только жесткой действительностью антипереполнения или 
переполнения стека. Программист должен иметь ясное представление относительно 
количества стековых входов, которые будут использованы выполнением слова и 
количества входов, которые будут помещены назад на стек выполнением слова. 
Наблюдение аномальных случаев на стеке данных - первая линия обороны, 
посредством чего программист может распознать ошибки в прикладной программе. 
Также стоит помнить, что множество ошибок стека вызванных ошибочным прикладным 
кодом, имеют часто равную и противоположную величину, вызывая комплиментарный 
(и вводящий в заблуждение) результат. 

По этим причинам и массе других причин, одна недвусмысленная, бесспорная, и 
необходимая дисциплина программирования, наблюдаемая начиная с самых ранних 
дней Рогіііі - это обеспечение стековых диаграмм для всех добавлений к 
прикладному словарю за исключением статических конструкций типа ѴАРІАВБЕ и 
ССШ5ТАІМТ . 

А.3.2.3.2 _ 

Стек потока управления 

Самое простое использование слов потока управления это реализовать базовые 
управляющие структуры, показанные на рисунке А.1. 
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Рисунок А.1 - Базовые образцы потока управления. 
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В потоке управления каждый переход или передача управления должны заканчиваться 
в некотором месте назначения. Естественная реализация использует стек, чтобы 
помнить начала переходов вперед и назначения ветвлений назад. Как минимум, 
только местоположение каждого начала или назначения должно быть обозначено, 
хотя другая зависящая-от-реализации информация также может быть сохранена. 

Начало - это непосредственно местоположение перехода. Назначение - то, где 
управление будет продолжено, если переход был принят. Назначение необходимо для 
разрешения адреса перехода для каждого начала, и наоборот, если каждая цепочка 
потока управления завершена, не может остаться никакое неиспользованное 
назначение. 

С добавлением только трех слов (АНЕАР, С5-Р0Ш и С5-РІСК), базовые слова потока 
управления поставляют примитивы, необходимые для компиляции разнообразных 
переносимых структур управления. Требуемые способности - компиляция прямого и 
обратного условного и безусловного переходов и организация во время компиляции 
начал и назначений переходов. Таблица 1 показывает желаемое поведение. 

Требование, чтобы слова потока управления были должным образом сбалансированы 
другими словами потока управления, делает разумным описание определенного 
реализацией стека потока управления во время компиляции. Нет никакого 
предписания относительно того, как стек потока управления реализован, например, 
стек данных, связанный список, специальный массив. Каждый элемент упомянутого 
выше стека потока управления - одинакового размера. 


Таблица А.1 - Поведение компиляции слов потока управления 


во время 

слово: 

КОМПИЛЯЦИИ 

поставки: 

, 

разрешения : 

используется для: 

ІР 

огід 


отмечает начало условного перехода вперед 

ТНЕІМ 


огід 

разрешает ІР или АНЕАР 

ВЕВІІМ 

сіезі 


отмечает назначение назад 

АОАІІЧ 


сіезі 

разрешает безусловный переход назад 

ЦИТИ 


сіезі 

разрешает условный переход назад 

АНЕАР 

огід 


отмечает начало безусловного перехода вперед 

СЗ-РІСК 



копирует элемент на стеке потока управления 

СЗ-РОШ 



переупорядочивает элементы на стеке потока 




управления 


С этим инструментарием могут быть определены оставшиеся базовые элементы 
управляющих структур, показанные на рисунке А.2; стековая нотация, используемая 
здесь для слов немедленного исполнения - это ( компиляция / выполнение). 

: Ѵ\/НІІ_Е ( сіезі; -- огід сіезі / Тіад -- ) 

\ условный выход из циклов 
Р05ТР0ІМЕ ІР \ условный переход вперед 

1 С5-Р0Ш \ сохранить сіезі: на верху 

; ІММЕРІАТЕ 
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: РЕРЕАТ ( огід сіезі ) 

\ разрешение единственного Ѵ\/НІІ_Е и возврат к ВЕ6ІІМ 
Р05ТР0ІМЕ А6АІІМ \ безусл. переход назад к сіезі 
Р05ТР0ІМЕ ТНЕ1М \ разрешение перехода вперед из огід 
; ІММЕРІАТЕ 

: Е1_5Е ( огіді -- огід2 / -- ) 

\ разрешение ІР обеспечивающего альтернативное выполнение 
Р05ТР0ІМЕ АНЕАР \ безусловный переход вперед огід2 






1 С5-Р0І_І_ \ положить огіді снова наверх 

Р05ТРСШЕ ТНЕМ \ разрешение перехода вперед из огіді 
; ІММЕРІАТЕ 
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Рисунок А.2 - Дополнительные базовые образцы потока управления. 

Поток управления Рогііі предоставляет решение для известной проблематики строго 
структурированного программирования. 

Базовые управляющие структуры могут быть дополнены, как показано в примерах на 
рисунке А. 3, с дополнительными Ѵ\/НІІ_Е в ВЕ6ІМ ... ІІІ\ІТІІ_ и ВЕ6ІМ ... \л/НІІ_Е ... 
РЕРЕАТ структурах. Однако, для каждого дополнительного, Ѵ\/НІІ_Е должен быть ТНЕМ 
в конце структуры. ТНЕМ завершает синтаксис с Ѵ\/НІІ_Е и указывает где продолжить 
выполнение, когда Ѵ\/НІІ_Е передаст управление. Использование больше чем одного 
дополнительного \л/НІІ_Е возможно, но не общепринято. Заметьте, что если 
пользователь находит это использование ТНЕМ нежелательным, может быть определен 
псевдоним с более приятным именем. 

Дополнительные действия могут быть выполнены между словом потока управления 
(РЕРЕАТ или ІІІ\ІТІІ_) и ТНЕІМ, которое соответствует дополнительному Ѵ\/НІІ_Е. Далее, 
если для нормального завершения и раннего завершения желательны дополнительные 
действия, альтернативные действия могут быть разделены обычным Рогіб ЕІ_5Е . 
Действия завершения - все определены после тела цикла. 
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Рисунок А.3 - Примеры расширения образцов потока управления. 

Заметьте, что РЕРЕАТ создает аномалию при сопоставлении Ѵ\/НІІ_Е с ЕІ_5Е или ТНЕІМ, 
более примечательную по сравнению с ВЕ6ІМ . . . ІІІ\ІТІІ_ случаем. То есть будет меньше 
одним ЕІ_5Е или ТНЕМ чем есть Ѵ\/НІІ_Е, потому что РЕРЕАТ разрешает один ТНЕІМ. Как 
и выше, если пользователь находит это число несоответствий нежелательным, 

РЕРЕАТ могло быть заменено его собственным действующим определением. 

Могут быть определены другие слова потока управления выхода из цикла, и даже 
другие циклы. Единственное требование - это что стек потока управления должным 
образом обслуживается и управляется. 

Простая реализация АІМ5 Рогііі САЗЕ структуры ниже - пример расширения 
управляющей структуры. Заметьте, обслуживание стека данных не допускает 
вмешательство со стороны возможного использования стека потока управления. 

0 С0ІМ5ТАІМТ САЗЕ ІММЕОІАТЕ ( иниц. счетчика ОР ) 

: ОР ( #оТ -- огід #оТ+1 / х -- ) 

1+ ( счетчик ОР ) 

>Р ( переместить со стека в случае, если ) 

( стек потока управления это стек данных. ) 

Р05ТР0ІМЕ ОѴЕР Р05ТР0ІМЕ = ( копир, и тест параметра сазе ) 

Р05ТР0ІМЕ ІР ( добавить огід на стек потока управления ) 

Р05ТР0ІМЕ ОРОР ( удалить сазе параметр если = ) 

П> ( мы должны теперь вернуть счетчик назад ) 

; ІММЕОІАТЕ 
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: ЕШОР ( огіді #оТ -- огід2 #оТ ) 

>Р ( переместить со стека в случае, если ) 

( стек потока управления это стек данных. ) 

Р03ТР0МЕ ЕЦЗЕ 

Р> ( мы должны теперь вернуть счетчик назад ) 

; ІММЕОІАТЕ 

: ЕШСА5Е ( огіді.. огідп #оТ -- ) 

Р03ТР0МЕ ОРОР ( удалить сазе параметр ) 

0 700 

Р03ТР0МЕ ТНЕМ 
ЮОР 

; ІММЕОІАТЕ 

А.3.2.3.3 _ 

Стек возвратов 

Ограничения в разделе, 3.2.3.3 Стек возвратов - являются необходимым, если 
реализации разрешают помещать параметры цикла на стеке возвратов. 

А.3.2.6 _ 

Запросы к окружению 

Размер в адресуемых элементах различных типов данных может быть определен 
фразами типа 1 СНАР5. Точно так же выравнивание может быть определено фразами 








типа 1 АІЛ6МЕ0. 


Запросы к окружению разделены на две группы: те, что всегда производят одно и 
тот же значение и те, которые не могут. Первые группы включают входы типа МАХ- 
N. Эта информация фиксирована аппаратными средствами или конструкцией системы 
РогІИ; пользователю гарантируется, что выяснение вопроса однажды является 
достаточным. 

Другая группа запросов - для вещей, которые могут законно изменяться через 
какое-то время. Например, приложение могло бы проверить присутствие набора слов 
двойных чисел, используя запрос среды. Если он отсутствует, система могла бы 
вызывать зависимый от системы процесс для загрузки набора слов. Системе 
разрешается изменить ЕМѴІРСШМЕМТ? базу данных так, чтобы последующие запросы об 
этом указывали, что он присутствует. 

Заметьте что запрос, который возвращает "ипкпоип" ответ, может производить 
"кпоип" результат на последующий запрос. 

А.3.3 _ 

Словарь Рогбб 

Стандартная Программа может переопределять стандартное слово на слово с 
нестандартным определением. Программа все еще Стандартная (так как она может 
быть построена на любой Стандартной системе), но результат делает объединенный 
объект (Стандартная система плюс Стандартная программа) нестандартной системой. 

А.3.3.1 _ 

Область имени 
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А.3.3.1.2 _ 

Имена определений 

Язык в этом разрезе должен гарантировать переносимость Стандартных Программ. 
Если программа использует кое-что вне Стандарта, что она не предоставляет 
самостоятельно, нет гарантии, что другая реализация будет иметь то, что 
необходимо программе для работы. Нет намерения, вообще предполагать, что все 
программы РогИп будут так или иначе недостаточными или худшими, потому что они 
- не стандартные; некоторые из самых прекрасных драгоценных камней 
программистского искусства будут нестандартными. В то же самое время, комитет 
пытается гарантировать что программа, помеченная как "стандартная" будет 
соответствовать некоторым ожиданиям, особенно в отношении переносимости. 

Во многих системных средах входной источник не способен поставлять некоторые 
неграфические символы из-за внешних факторов, типа использования этих символов 
для управления потоком данных или редактирования. Кроме того, при интерпретации 
из текстового файла, функция синтаксического анализа специфически обрабатывает 
неграфические символы подобно пробелам; таким образом, слова полученные 
текстовым интерпретатором не будут содержать внедренные неграфические символы. 
Разрешение реализациям в таких средах называть себя Стандартными, является 
необходимым незначительным ограничением на Стандартные программы. 

Стандартной системе позволяется разрешать создание имен определений, содержащих 
неграфические символы. Исторически, такие имена использовались для функций 
редактирования с клавиатуры, и "невидимых" слов. 

А.3.3.2 _ 

Область кода 

А.3.3.3 _ 


Область данных 



Слова #ТІВ, >ІІ\І, ВАЗЕ, ВЕК, 5СК, 506ІПСЕ, 506ІПСЕ-Ю, ЗТАТЕ, и ТІВ содержат 
информацию, используемую системой РогЕб в ее операциях, и могут быть 
использованы приложениями. Любое предположение сделанное приложением о данных 
доступных в системе РогЕб, которые хранятся иначе, чем данные только что 
перечисленные - зависимость от окружения. 

Нет никакого смысла в определении (в Стандарте) что является, и что не является 
адресуемым. 

Стандартная Программа НЕ может адресовать: 

- Непосредственно в стеки данных или возвратов; 

- В поле данных определения, если не сохраненное приложением. 

Ограничения только для чтения возникают потому, что некоторые системы РогЕб 
работают из РОМ и некоторого разделения буферов ввода-вывода с другими 
пользователями или системами. Переносимые программы не могут знать, какие 
области затронуты, отсюда общие ограничения. 

А.3.3.3.1 _ 

Выравнивание адреса 

Много процессоров имеют ограничения на адреса, которые могут использоваться 
командами доступа к памяти. Например, на МоЕогоІа 680ѲѲ, 16-бит или 32-бит 
данные могут быть доступны только в четных адресах. Другие примеры включают 
архитектуру РІЗС, где 16-бит данные могут быть загружены или сохранены только в 
четных адресах и 32-бит данные только в адресах, которые кратны четырем. 
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Разработчик А№ РогЕб может справляться с этими ограничениями выравнивания 
одним из двух способов. Слова доступа к памяти РогЕб (@, !, +!, и т.д.) мог 
быть реализованы в терминах инструкций доступа меньшей-ширины, которые не имеют 
ограничений выравнивания. Например, на 680Ѳ0 РогЕб с 16-бит ячейками, @ могло 
быть реализовано двумя 68000 командами выборки байта и повторной сборкой байтов 
в 16-бит ячейке. Хотя это скрывает аппаратные ограничения от программиста, это 
неэффективно, и может иметь непреднамеренные побочные эффекты в некоторых 
аппаратных средах. Альтернативная реализация А№ РогЕб могла определять каждое 
слово доступа к памяти, с использованием родных команд, которые наиболее близко 
соответствуют функциям слов. В 68000 РогЕб с 16-бит ячейками, § использовало бы 
68000 16-бит команду перемещения. В этом случае, ответственность за передачу к 
§ правильно выровненного адреса ложится на программиста. Переносимая А№ РогЕб 
программа должна предполагать, что выравнивание может требоваться и следовать 
требованиям этого раздела. 

А.3.3.3.2 _ 

Непрерывные области 

Область данных системы РогЕб входит в прерывистые области! Местоположение 
некоторых областей предоставлено системой, некоторых - программой. Область 
данных непрерывна в пределах областей, позволяя адресной арифметике 
генерировать допустимые адреса только в пределах отдельной области. Стандартная 
Программа не может делать никакие предположения об относительном размещении 
множественных областей в памяти. 

Раздел 3.3.3.2 предписывает условия, при которых могут быть получены 
непрерывные зоны области данных. Например: 

СПЕАТЕ ТАВбЕ 1 С, 2 С, АНСИ 1000 , 2000 , 
делает таблицу, чей адрес возвращается ТАВбЕ. При доступе к этой таблице, 


ТАВбЕ С@ 

ТАВбЕ СНАР+ С@ 


возвратит 1 
возвратит 2 



ТАВБЕ 2 СНАР5 + АБІ6МЕ0 § 

ТАВЕЕ 2 СНАП5 + АІЛ6МЕ0 СЕББ+ § 


возвратит 10ѲѲ 
возвратит 2000. 


Точно так же, 

СВЕАТЕ ОАТА 1000 АББОТ 

делает массив в размере 1000 адресуемых элементов. Более переносимая стратегия 
определила бы массив в прикладных элементах, типа: 

500 СО№ТАМТ ІЧСЕЕЕ5 

СКЕАТЕ СЕЕЕ-РАТА ІМСЕЕЕ5 СЕББЗ АББОТ 
Этот массив может быть индексирован подобно этому: 

: БООК ІМСЕЕЕ5 0 00 СЕББ-ОАТА I СЕББЗ + ? БООР ; 


А.3.3.3.6 _ 

Другие временные области 

Во многих существующих системах РогБб, эти области - в НЕВЕ или сразу вне ее, 
отсюда многие ограничения. 
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(2*п)+2 - размер символьной строки, содержащей без знаков препинания двоичное 
представление максимального двойного числа с ведущим знаком "минус" и 
завершающим пробелом. 

Примечание реализации: Так как минимальное значение п - это 16, абсолютный 
минимальный размер выходной строки отображаемого числа - 34 символа. Но если 
ваша реализация имеет больший п, вы должны также увеличить размер выходной 
строки отображаемого числа. 

А.3.4 _ 

Интерпретатор текста РогЕб 

А.3.4.3 _ 

Семантика 

"Семантика инициирования" соответствуют коду, который выполняется после входа в 
определение, аналогично коду, выполняемому ЕХІТ после выхода из определения. 
"Семантика времени-выполнения" соответствует кодовым фрагментам, типа литералов 
или ветвлений, которые откомпилированы внутри определения через двоеточие 
словами с явной семантикой компиляции. 

В кросс-компиляторе РогБИ может быть определена семантика выполнения, чтобы 
иметь место только в главной системе, только в целевой системе, или в обеих 
системах. Например, это может быть свойственно словам типа СЕББЗ выполняющимся 
на главной системе и возвращающим значение описывающее целевую, для определений 
через двоеточие выполняющимся только на целевой, и для С0Н5ТАІМТ и ѴАРІАВЕЕ 
имеющих поведение при выполнении на обеих системах. Подробности поведения 
кросс-компилятора вне контекста этого Стандарта. 

А.3.4.3.2 _ 

Семантика интерпретации 

Ввиду разнообразных причин, этот Стандарт не определяет семантику интерпретации 
для каждого слова. Примеры этих слов - >П, .", 00, и ІР. Ничто в этом Стандарте 
не препятствует реализациям обеспечивать семантику интерпретации для этих слов, 
типа интерактивные слова потока управления. Однако, Стандартные Программы не 
могут использовать их в состоянии интерпретации. 



А.3.4.5 _ 

Компиляция 

Рекурсия компилятора на уровне определения потребляет чрезмерные ресурсы, 
особенно поддержка Іосаіз . Технический Комитет не полагает, что выгоды 
покрывают затраты. Вложение определений - также не общая практика и не будет 
работать на многих системах. 

А. 4 _ 

Документационные требования 

А.4.1 _ 

Системная документация 

А.4.2 _ 

Программная документация 

А. 5 _ 

Соглашение и наименование 

А.5.1 _ 

А№ РогІІі системы 
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Раздел 5.1 определяет критерии, которым система должна удовлетворять, чтобы 
оправдывать обозначение "А№ РогИп Система". Кратко, минимальное требование - 
это система должна "реализовать" Основной набор слов. Есть несколько путей, 
которыми это требование может быть выполнено. Наиболее очевидное - что все 
Основные слова могут быть в пред-откомпилированном ядре. Однако это не 
единственный путь удовлетворения требования. Например, некоторые слова могут 
быть предоставлены в исходных блоках или файлах с командами, объясняющими как 
добавлять их в систему, если они необходимы. Пока слова предоставлены таким 
способом, что пользователь может получить доступ к ним с ясной и прямой 
процедурой, они могут рассматриваться как присутствующие. 

Кросс-компилятор РогІН имеет много характерного общего с А№ РогІН Системой, в 
том числе оба используют подобные средства компиляции для обработки программы. 
Однако чтобы полностью определить А№ РогИп кросс-компилятор, было бы 
необходимо обращаться к сложным проблемам, имеющим дело с компиляцией и 
семантикой выполнения в ведущих и целевых средах также как проблемам РОМ- 
базирования. Степень усилий для выполнения этого должным образом, оказывается 
не практичной в это время. В результате, хотя может быть возможно для РогІИ 
кросс-компилятора правильно готовить А№ РогІП программу к выполнению в целевой 
среде, неуместно для кросс-компилятора быть обозначенным А№ РогІИ Системой. 

А.5.2 _ 

А№ РогІІі программы 

А.5.2.2 _ 

Программное наименование 

Объявление зависимости от окружения не должно рассматриваться нежелательным, 
просто подтверждение, что автор воспользовался преимуществом некоторой принятой 
архитектуры. Например, большинство компьютеров в обычном использовании основано 
на двоичной арифметике дополнительного кода (дополнение до двух). Подтверждая 
зависимость от окружения на этой архитектуре, программист становится имеющим 
право использовать число -1, чтобы представить весь набор битов без 
значительного ограничения переносимости программы. 


Поскольку все программы требуют пространства для данных и команд, и времени, 
чтобы выполнить эти команды, они зависят от присутствия среды, предоставляющей 
эти ресурсы. Невозможно предсказать как мало некоторых из этих ресурсов 



(например, стековое пространство) может быть необходимо для исполнения 
некоторой задачи, поэтому этот Стандарт так не делает. 

С другой стороны, поскольку программа требует увеличивающихся уровней ресурсов, 
будет вероятно постепенно меньшее количество систем, на которых она выполнится 
успешно. Алгоритм требующий массива 1Ѳ9 ячеек мог бы работать на меньшем 
количестве компьютеров чем требующий только 1ѲЗ. 

Так как нет также никакого способа знать, какой минимальный уровень ресурсов 
будет реализован в системе полезной, по крайней мере, для некоторых задач, 
любая программа, выполняющая реальную работу, и помеченная просто "А№ Рогбй 
Программа" вряд ли помечена правильно. 
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А.6 _ 

Словарь 

В этом и последующих разделах мы представляем объяснения для обработки 
специфических слов: почему мы включили их, почему мы поместили их в некоторые 
наборы слов, или почему мы так определили их имена или значение. 

Слова в этом разделе организованы в наборы слов, с сохранением их индексных 
номеров для простой системы перекрестных ссылок к словарю. 

Исторически, много систем Рогій были написаны в Рогбй. Многие из слов в Рогбй 
первоначально имели как первичную цель непосредственно поддержку системы Рогбй. 
Например, МОРО и РІШ часто используются как основные инструменты 
интерпретатора текста Рогій, и СПЕАТЕ во многих системах - примитив для 
формирования входов словаря. В определении слов типа этих стандартным способом, 
мы пытались не препятствовать их использованию разработчиками. Одна из 
возможностей Рогій, который вызвал любовь к нему его пользователей - это то, 
что одни и те же инструментальные средства, использующиеся для реализации 
системы, являются доступными прикладному программисту - результат этого подхода 
это компактность и эффективность, которая характеризует большинство реализаций 
Рогбй. 

А.6.1 _ 

Основные слова 

А.6.1.0Ѳ7Ѳ 

Типичное использование: 

... ' пате . 

Много систем Рогій используют это изящное слово. Многие нет. А№ Рогбй 
наследует использование Рогбй 83. 

См.: 3.4.3. .2 Семантика интерпретации, А.6.1.1550 РІШ. 

А.6.1.0080 ( 

Типичное использование: 

( ссс) . . . 

А. 6.1.0140 +1_00Р 

Типичное использование: 

: X . . . Іітіі: Тігзі; 00 . . . збер +1_00Р ; 


А.6.1.0150 

Использование , (запятая) для компиляции идентификаторов исполнения - не 
переносимое. 


См. : 6.2.0945 С0МРИЕ, . 



А.6.1.0190 

Типичное использование: 

: X ... ." ссс" ... ; 

Реализация может определять семантику интерпретации для ." если желательно. В 
одной вероятной реализации, интерпретация ." отобразила бы разграниченное 
сообщение. В другой вероятной реализации, интерпретация ." компилировала бы код 
для отображения сообщения позже. В еще другой вероятной реализации, 
интерпретация ." была бы обработана как исключение. Обусловленная этими 
вариантами Стандартная Программа не может использовать ." при интерпретации. 
Точно так же Стандартная Программа не может компилировать Р05ТР0МЕ ." внутри 
нового слова, и затем использовать это слово при интерпретации. 


161 


А.6.1.0320 2* 

Исторически 2* было реализовано на машинах с дополнительным кодом (дополнение 
до двух) как логическая команда левого сдвига. Умножение на два - эффективный 
побочный эффект на этих машинах. Однако смещение подразумевает знание значения 
и позиции битов в ячейке. В то время как имя подразумевает умножение, 
большинство разработчиков использует аппаратный левый сдвиг для реализации 2*. 

А.6.1.0330 2/ 

Это слово имеет то же самое общее использование и следствие неверного названия 
как 2*. Оно часто реализовано на машинах с дополнительным кодом (дополнение до 
двух) с аппаратным правым сдвигом, который распространяет знаковый разряд. 

А.6.1.0350 2@ 

Для 2§ порядок сохранения определен Стандартом. 

А. 6.1.0450 : 

Типичное использование: 

: пате ... ; 

В Рогій 83, это слово было определено для изменения порядка поиска. Эта 
спецификация явно удалена в этом Стандарте. Мы полагаем, что в большинстве 
случаев это не имеет никакого эффекта; однако системы, которые разрешают много 
порядков поиска, нашли Рогіііл -83 поведение двоеточия очень нежелательным. 

Заметьте, что двоеточие самостоятельно не вызывает компилятор. Двоеточие 
устанавливает состояние компиляции так, чтобы более поздние слова в области 
анализа были откомпилированы. 

А.6.1.0460 ; 

Типичное использование: 

: пате ... ; 

Одна функция выполняемая ; и ;СОЭЕ это позволить текущему определению быть 
найденным в словаре. Если текущее определение было создано с помощью :ШМАМЕ 
текущее определение не имеет имя определения и таким образом не может быть 
найдено в словаре. Если :ШМАМЕ реализовано, компилятор Рогіій должен сохранить 
достаточно информации о текущем определении, чтобы позволить ; и ;СОЭЕ 
определить, действительно ли должно быть предпринято какое либо действие, чтобы 
позволить ему быть найденным. 

А.6.1.0550 >ВОЭУ 

а-асісіг - адрес, который НЕРЕ возвратило бы, если бы было выполнено немедленно 
после выполнения СРЕАТЕ которое определило хі . 

А.6.1.0680 АБОРТ" 

Типичное использование: 

: X ... Іезі АБОРТ" ссс" ... ; 



А.6.1.Ѳ695 АССЕРТ 

Предыдущие стандарты определяли, что накопление входной строки заканчивается, 
когда получен "возврат" или когда было получено +п1 символов. Завершение, когда 
было получено +п1 символов, трудно, дорого, или невозможно осуществить в 
некоторых системных средах. Следовательно, множество существующих реализаций не 
подчиняется с этим требованиям. 
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Так как редактирование строки и функции накопления часто реализуются системными 
компонентами вне контроля реализацией Рогбб, этот Стандарт не налагает никакое 
такое требование. Стандартная Программа может только предполагать, что она 
может получать ввод строки от АССЕРТ или ЕХРЕСТ. Детальная последовательность 
пользовательских действий, необходимых для подготовки и передачи этой строки, 
вне контекста этого Стандарта. 

Спецификация ненулевого, положительного целочисленного счетчика (+п1) для 
АССЕРТ позволяет некоторым разработчикам продолжать их практику использования 
нуля или отрицательной величины как флага для вызова специального поведения. 
Поскольку такое поведение вне Стандарта, Стандартные программы не могут 
зависеть от этого, но Технический Комитет не желает излишне препятствовать 
этому. Так как фактические значения - почти всегда маленькие целые числа, 
никакие функциональные возможности не повреждаются этим ограничением. 

АССЕРТ и ЕХРЕСТ исполняют схожие функции. АССЕРТ рекомендуется для новых 
программ, и будущее использование ЕХРЕСТ, не одобряется. 

Рекомендуется, чтобы все неграфические символы были зарезервированы для функций 
редактирования или управления и не были сохранены во входной строке. 

Обычно, когда пользователь готовит входную строку, которая будет передана 
программе, система позволяет пользователю редактировать эту строку и исправлять 
ошибки перед передачей заключительной версии строки. Функция редактирования 
предоставлена иногда непосредственно Рогбб системой, и иногда внешним системным 
программным обеспечением или аппаратными средствами. Таким образом, управляющие 
символы и функции не могут быть доступны на всех системах. В обычном случае 
конец процесса редактирования и заключительной передачи строки обозначается 
пользователем нажатием клавиши "Ребигп" или "Епбег". 

Как в предыдущих стандартах, ЕХРЕСТ возвращает входную строку немедленно после 
ввода требуемого числа символов, а также когда получен признак конца строки. 
Широко рассматриваемое поведение "автоматического завершения, после того как 
было введено определенное количество символов" нежелательно, потому что 
пользователь "потеряет контроль" процесса входного редактирования в 
потенциально неизвестное время (пользователь не обязательно знает, сколько 
символов требовалось от, ЕХРЕСТ). Таким образом, ЕХРЕСТ и 5РАІМ были сделаны 
устаревшими и существуют в Стандарте только как уступка существующим 
реализациям. Если ЕХРЕСТ существует в Стандартной Системе, оно должно иметь 
поведение "автоматического завершения". 

АССЕРТ не имеет поведения "автоматического завершения" ЕХРЕСТ. Однако, потому 
что внешние системные аппаратные средства и программное обеспечение могут 
исполнять функцию АССЕРТ, когда получен признак конца строки действие курсора, 
и, следовательно, отображение - определенное реализацией. Рекомендуется, чтобы 
курсор остался немедленно после введенного текста после получения признака 
конца строки. 

А.6.1.Ѳ7Ѳ5 АІЛСИ 

В этом Стандарте мы попытались предусмотреть переносимость между различными СРІІ 
архитектурами. Одна из частых причин проблем переносимости - требование 
выровненных на ячейку адресов на некоторых СРІІ. На этих системах АІЛ6ІМ и 
АІЛСІМЕО могут требоваться, чтобы формировать и прослеживать структуры данных, 
сформированные с помощью С,. Разработчики могут определять эти слова как пустые 



команды на системах, для которых они - не функциональны. 

А.6.1.Ѳ7Ѳ6 АШбИЕО 
См. : А.6.1.Ѳ7Ѳ5 АІЛ6М. 
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А.6.1.0760 ВЕ6ІМ 
Типичное использование: 

: X . . . ВЕ6ІМ . . . Цезі ІІИТШ ; 

или 

: X . . . ВЕ6ІМ . . . Цезі ИНШЕ . . . РЕРЕАТ ; 

А.6.1.Ѳ77Ѳ ВЦ 

Поскольку пробел используется повсюду в РогШі как стандартный разделитель, это 
слово единственный путь программе найти и использовать системное значение 
"пробела". Значение символа пробела не может быть получено с помощью СНАР, 
например. 

А. 6.1.0880 СЕШ+ 

Как АШСМ и АШ6МЕР, слова СЕШ и СЕШ+ были добавлены, чтобы помочь в 
переносимости между системами с различными размерами ячейки. Они предназначены 
для использования в управлении индексами и адресами в целых числах размеров 
ячеек. 

Пример: 

2ѴАРІАВЦЕ РАТА 
0 100 РАТА 2! 

РАТА @ . 100 
РАТА СЕШ+ § . 0 

А. 6.1.0890 СЕШ5 
См. : А.6.1.0880 СЕШ+ . 

Пример: 

СРЕАТЕ ІМІІМВЕР5 100 СЕШ5 АШОТ 

( Назначает пространство в массиве ІМІІМВЕР5 для 100 ячеек данных.) 

А. 6.1.0895 СНАР 
Типичное использование: 

. . . СНАР А СО№ТАІ\ІТ "А" . . . 

А. 6.1.0950 СО№ТАИТ 
Типичное использование: 

. . . РЕСІМАЦ 10 СОИЗТАІМТ ТЕИ ... 

А.6.1.1000 СРЕАТЕ 

Адрес области данных слова, определенного СРЕАТЕ, дается указателем области 
данных немедленно после выполнения СРЕАТЕ. 

Резервирование пространства поля данных типично делается с помощью АШОТ. 

Типичное использование: 

... СРЕАТЕ 50МЕТНІМ6 ... 
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А.6.1.1240 00 

Типичное использование: 

: X ... ІітіЦ ТІГ5Ц РО 


или 


X ... ІітіЦ ТігзЦ РО 


ЦООР ; 

зіер +ЦООР ; 


А.6.1.1250 00Е5> 

Типичное использование: 



X ... 00Е5> 


Относительно 00Е5>, Стандартная Программа не может делать какие-либо 
предположения относительно способности находить имя определения содержащего 
00Е5> или любое предыдущее определение чье имя может быть скрыто этим. 00Е5> 
эффективно заканчивает одно определение и начинает другое насколько 
заинтересованы переменные Іосаі и структуры потока управления. Поведение 
компиляции проясняет, что пользователь не имеет право помещать 00Е5> внутри 
любых структур потока управления. 

А.6.1.1310 ЕІ_5Е 
Типичное использование: 

: X . . . Тез*: ІР . . . ЕІ_5Е . . . ТНЕМ ; 

А. 6.1.1345 ЕІЧѴІРОММЕІЧТ? 

В Стандартной Системе, которая содержит только Основной набор слов, эффективное 
использование ЕІМѴІПОММЕІМТ? требует или его использования в пределах 
определения, или использования обеспеченного пользователем вспомогательного 
определения. Основной набор слов испытывает недостаток прямого метода сборки 
строки в состоянии интерпретации (11.6.1.2165 5" находится в дополнительном 
наборе слов), а также средства для проверки возвращенного флага в состоянии 
интерпретации (например, дополнительный 15.6.2.2532 [ІР]). 

Комбинация 6.1.1345 ЕІЧѴІРОММЕІЧТ?, 11.6.1.2165 5", 15.6.2.2532 [ІР], 15.6.2.2531 
[ЕІ_5Е] , апсі 15.6.2.2533 [ТНЕІМ] составляет эффективный набор слов для условной 
компиляции, которая работает в состоянии интерпретации. 

А. 6.1.1360 ЕѴАШАТЕ 

Технический Комитет знает, что эта функция обычно записывается как ЕѴАІ_. Однако 
существуют реализации, которые могут страдать от определения слова сделанного 
так как здесь. Мы также находим ЕѴАШАТЕ более читабельным и ясным. Было 
некоторое мнение для вызова ІІМТЕПРПЕТ, но это также имело бы нежелательные 
действия на существующий код. Длинное написание не считали существенным, так 
как это - не то слово, которое должно использоваться часто в исходном тексте. 

А.6.1.1380 ЕХІТ 
Типичное использование: 

: X ... Іезі ІР ... ЕХІТ ТНЕМ ... ; 
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А.6.1.1550 РІШ 

Одна из более трудных проблем, которые Комитет решал, была проблема отделения 
спецификации механизмов реализации от спецификации РогІИ языка. Могут быть 
быстро перечислены три основных подхода реализации: 

1 ) 

Механизмы шитого кода. Это традиционные подходы к реализации Рогій, но могут 
использоваться другие методы. 

2 ) 

Подпрограммный шитый с "макрорасширением" (копирование кода). Короткие 
подпрограммы, подобно коду для ОІІР, скорее скопированы в определение, чем 
скомпилирована ЭЗР ссылка. 

3) 

Непосредственное кодирование с оптимизацией. Это может включать оптимизацию 
стека (заменяющую такие фразы как 5\л/АР РОТ + одной или двумя машинными 
командами, например), распараллеливание (тенденция в более новых чипах РІ5С - 
это иметь несколько функциональных подэлементов которые могут выполняться 
параллельно), и так далее. 


Первоначальное требование (унаследованное от РогІИ 83) это адреса компиляции 



откомпилированы в словарь, исключая типы реализации 2 и 3. 


Типа 3 механизмы и оптимизации типа 2 реализаций, были затруднены явной 
спецификацией непосредственного исполнения или не непосредственного исполнения 
всех стандартных слов. Р05ТРСШЕ позволяет де-спецификацию непосредственного 
исполнения или не непосредственного исполнения для всех кроме нескольких слов 
РогТИ, чье поведение должно быть ЗТАТЕ -независимо. 

Один тип 3 реализации, строгій Чарльза Мура, имеет версии компиляции и 
интерпретации многих слов РогТІі. В настоящем, это, кажется общим подходом для 
типа 3 реализации. Комитет чувствовал, что этот подход реализации должен быть 
разрешенным. Следовательно, возможно, что слова без семантики интерпретации 
могут быть найдены только в течение компиляции, и другие слова могут 
существовать в двух версиях: версия компиляции и версия интерпретации. 
Следовательно, значения возвращенные РІШ, могут зависеть от ЗТАТЕ, и ' и ['] 
могут быть не способны найти слова без семантики интерпретации. 

А.6.1.1561 РМ/МСЮ 

Представляя требование для "минимального" деления, РогТб 83 произвел много 
споров и беспокойств со стороны тех, кто предпочли более обычную практику, 
поддерживаемую в других языках, реализации деления согласно поведению ведущего 
СРІІ, которое наиболее часто симметричное (округленное к нулю) . В попытке найти 
компромиссную позицию, этот Стандарт предусматривает примитивы для обеих общих 
разновидностей, минимального и симметричного (см. 5М/НЕМ). РМ/МСЮ - минимальная 
версия. 

Технический Комитет рассмотрел обеспечение двух законченных наборов явно 
именованных операторов деления, и отказался делать так на том основании, что 
это незаконно увеличило бы и усложнило Стандарт. Вместо этого, разработчики 
могут определять нормальные слова деления в терминах или РМ/МСЮ или 5М/НЕМ, 
предоставляя обоснование их выбора. Пожелание людей иметь явно именованные 
наборы операторов поощряются. РМ/МСЮ может использоваться, например, для 
определения: 
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/_МСЮ ( п1 п2 -- пЗ п4) >Н 5Ю Н> РМ/МСЮ ; 

/_ ( п1 п2 -- пЗ) /_МСЮ 5Ѵ\/АР ОПОР ; 

_М00 ( п1 п2 -- пЗ) /_М00 ОПОР ; 

*/_М00 ( п1 п2 пЗ -- п4 п5) >Н М* Н> РМ/МОО ; 
*/_ ( пі п2 пЗ -- п4 ) */_М00 5ЫАР ОПОР ; 


А.6.1.1700 ІР 
Типичное использование: 

: X ... без! ІР ... ТНЕМ ... ; 

или 

: X ... ТезТ ІР ... ЕІ_5Е ... ТНЕМ 

А.6.1.1710 ІММЕОІАТЕ 
Типичное использование: 

: X ... ; ІММЕОІАТЕ 


А.6.1.1720 ІМѴЕПТ 

Слово N01 было первоначально предусмотрено в РогТб как оператор флага, чтобы 
делать структуры управления читаемыми. При его назначенном использовании 
следующие два определения произвели бы идентичный результат: 

: ОМЕ ( Тіад -- ) 

ІР ." Тше" ЕІ_5Е ." Таізе" ТНЕМ ; 

: ТѴ\Ю ( Тіад - - ) 

N01 ІР ." Таізе" ЕІ_5Е ." Тгие" ТНЕМ ; 




Это было обычное использование до РогШі-83 Стандарта, который переопределил N01 
как в ячейку шириной операцию обратного кода (дополнение до единицы), 
функционально эквивалентную фразе -1 ХОР. В то же самое время, тип данных, 
управляемый этим словом был изменен от флага до набора битов в ячейку шириной, 
и стандартное значения для Цше было изменено с "1" (набор только бита младшего 
разряда) на "-1" (весь набор битов). Поскольку эти определения ТРІІЕ и N01 были 
несовместимы с их предыдущими определениями, много пользователей РогЦй 
продолжают полагаться на старые определения. Следовательно, обе версии 
находятся в общем использовании. 

Поэтому использование N01 не может быть стандартизировано в это время. Два 
традиционных значения N01 - это отрицание смысла флага и выполнение операции 
обратного кода (дополнение до единицы) - сделаны доступными благодаря 0= и 
ШѴЕРТ, соответственно. 

А.6.1.1730 3 

Э может только использоваться со вложенными, 00...Ц00Р, 00...+Ц00Р, 700...Ц00Р, 
ог 700... +Ц00Р, например, в форме: 

: X ... 00 ... 00 ... Э ... 1_00Р . . . +1_00Р ... ; 
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А.6.1.1760 ЦЕАѴЕ 

Заметьте, что ЦЕАѴЕ немедленно завершает цикл. Никакие слова после ЦЕАѴЕ в 
пределах цикла не будут выполнены. 

Типичное использование: 

: X ... 00 ... ІР ... ЦЕАѴЕ ТНЕN ... Ц00Р ... ; 

А. 6.1.1780 ШТЕРАЦ 
Типичное использование: 

: X ■ ■ ■ [ х ] ШТЕРАЦ ... ; 


А.6.1.1800 Ц00Р 
Типичное использование: 

: X . . . ИтШ ТІГ5Ц 00 . . . Ц00Р 


или 


X ... ІітіЦ ТігзЦ ?00 ... Ц00Р 


А.6.1.1810 М* 

Это слово - полезный ранний шаг в вычислениях, давая реальную дополнительную 
точность. Это было в использовании, начиная с РогЦб систем начала 1970-ых. 


А.6.1.1900 М0ѴЕ 

СМ0ѴЕ и СМ0ѴЕ> - первичные операторы перемещения в РогШі 83. Они определяют 
поведение для перемещения, которое предполагает размножение, если перемещение 
вызвано соответствующим образом. В некоторых аппаратных средствах, это 
специфическое поведение не может быть достигнуто, используя самую лучшую 
команду перемещения. Кроме того, СМ0ѴЕ и СМ0ѴЕ> перемещают символы; А№ РогЦб 
нуждается в команде перемещения, способной иметь дело с адресуемыми элементами. 
Таким образом, М0ѴЕ было определено и добавлено к Основному набору слов, и 
СМ0ѴЕ и СМ0ѴЕ> были перемещены в Строковый набор слов. 

А.6.1.2033 Р05ТР0NЕ 
Типичное использование: 

: ЕМ0ІР Р05ТР0NЕ Т^ ; ІММЕРІАТЕ 
: X ... ІР ... ЕМ0ІР ... ; 

Р05ТР0NЕ заменяет большинство функциональных возможностей С0МРШЕ и [С0МРШЕ] . 
СОМРШЕ и [СОМРШЕ] используются для той же самой цели: отложить поведение 
компиляции следующего слова в области анализа. СОМРШЕ было предназначено для 
применения к словам не немедленного исполнения и [СОМРШЕ] к словам 
немедленного исполнения. Это отягощает программиста необходимостью знать, какие 



слова в системе немедленного исполнения. Следовательно, стандарты Рогбб должны 
были определить немедленное исполнение или не немедленное исполнение всех слов, 
охваченных Стандартом. Это излишне сдерживает разработчиков. 

Вторая проблема с СОМРИЕ - это что некоторые программисты договорились 
предполагать и использовать специфическую реализацию, а именно: 

: СОМРИЕ Р> ОІІР § , СЕІ_І_+ Ж ; 
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Эта реализация не будет работать на системе Рогбб с непосредственным кодом. В 
непосредственном коде Рогбб использующем іпііпе расширение кода и локальную 
оптимизацию, размер произведенного объектного кода изменяется; эту информацию 
трудно сообщить "тупому" СОМРИЕ. "Разумный" (то есть, немедленного исполнения) 
СОМРИЕ, не имел бы этой проблемы, но это запрещали предыдущие стандарты. 

По этим причинам, СОМРИЕ не был включен в Стандарт, и [СОМРИЕ] был перемещен 
в пользу Р05ТР0ІМЕ . Дополнительное обсуждение может быть найдено в Науез, Э.Р., 
"Розбропе", Доклады 1989 Росйезбег Рогбб Сопбегепсе. 

А. 6.1.2120 РЕСІІР5Е 
Типичное использование: 

: X . . . РЕСІІР5Е ... ; 

Это - оператор рекурсии Рогбй; на некоторых реализациях оно вызывает САМО СЕБЯ. 
Обычный пример - кодирование функции факториала. 

: РАСТОРІАБ ( +ПІ -- +п2) 

ОІІР 2 < ІР ЭРОР 1 ЕХІТ ТНЕІ\| 

ОІІР 1- РЕСІІР5Е * 


п2 = пі(пі-і)(п1-2) ...(2)(1), произведение пі со всеми положительными целыми 
числами меньше чем оно само (как специальный случай, нулевой факториал 
равняется одному). Хотя возлюбленная компьютерными учеными, рекурсия делает 
необычно тяжелым использование обоих стеков и должна, поэтому быть использована 
с осторожностью. См. альтернативное определение А.6.1.2140 РЕРЕАТ. 

А.6.1.2140 РЕРЕАТ 
Типичное использование: 

: РАСТОРІАБ ( +ПІ -- +п2) 

ОІІР 2 < ІР ОРОР 1 ЕХІТ ТНЕМ 
ОІІР 

ВЕ6ІІЧ ОІІР 2 > ИННЕ 
1- ЗѴУАР ОѴЕР * 5МАР 
РЕРЕАТ ОРОР 


А.6.1.2165 5" 

Типичное использование: 

: X ... 5" ссс" ... ; 

Это слово найдено во многих системах под именем " (кавычка). Однако текущая 
практика состоит в почти равномерном разделении в использовании ": многие 
системы, используют семантику выполнения учитываемую здесь, в то время как 
другие возвращают адрес строки со счетчиком. Мы делаем здесь попытку 
удовлетворить оба лагеря, предусматривая два слова, 5" и Расширение Основного 
слова С" так, чтобы пользователи могли иметь любое поведение ими ожидаемое с 
простой операцией переименования. 
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А.6.1.2214 5М/РЕМ 

См. предыдущее обсуждение деления под РМ/МСЮ. 5М/РЕМ - примитив симметричного 
деления, который позволяет программам определять следующие операторы 
симметричного деления: 

: /-РЕМ ( п1 п2 -- пЗ п4 ) >Р 5>Р Р> 5М/РЕМ ; 

: /- ( п1 п2 — пЗ ) /-РЕМ ЗМАР РРОР ; 

: -РЕМ ( пі п2 -- пЗ ) /-РЕМ РРОР ; 

: Ѵ-РЕМ ( пі п2 пЗ — п4 п5 ) >Р М* Р> 5М/РЕМ ; 

: V- ( пі п2 пЗ -- п4 ) Ѵ-РЕМ ЗМАР РРОР ; 

А. 6.1.2216 501ІРСЕ 

ЗОІІРСЕ упрощает процесс непосредственного доступа к входному буферу, скрывая 
различия между его местоположением для различных входных источников. Это также 
дает разработчикам больше гибкости в их реализациях механизмов буферизации для 
различных входных источников. Комитет удалился от входной буферной спецификации 
состоящей из коллекции индивидуальных переменных, объявляя ТІВ и #ТІВ 
устаревшими. 

ЗОІІРСЕ в этой форме существует в Р83, РОІ_ѴРОРТН, І_МІ'5 РогІІіз и других. В 
обычных системах это эквивалентно фразе 

В1_К § ІР ВІ_К § ВЦОСК 1024 ЕІ_5Е ТІВ #ТІВ § ТНЕМ 

А.6.1.2250 5ТАТЕ 

Хотя ЕѴАШАТЕ, ЮАР, ІІ\ІСІ_ІІ0Е-РІІ_Е, и ІМСІ_ІЮЕО не перечислены как слова, которые 
изменяют 5ТАТЕ, текст, интерпретируемый любым из этих слов, может включать одно 
или более слов, которые явно изменяют ЗТАТЕ. ЕѴАІ_ІІАТЕ, ЮАР, ІІМСШОЕ-РШЕ, и 
ІІ\ІСІ_ІЮЕО сами не делают изменения в ЗТАТЕ. 

ЗТАТЕ не вложено при вложении текстового интерпретатора. Например, 
последовательность кода: 

: Р00 5" ]" ЕѴАШІАТЕ ; Р00 

оставит систему в состоянии компиляции. Точно так же после выполнения ЮАО с 
блоком содержащим ], система будет в состоянии компиляции. 

Заметьте, что ] не затрагивает область анализа и что единственное влияние 
которое : оказывает на область анализа, это выделить слово. Это дает право 
программе использовать эти слова для установки состояния с известными побочными 
эффектами на область анализа. Например: 

: ИОР : Р05ТР0ІМЕ ; ІММЕОІАТЕ ; 

МОР АІ_І6ІМ МОР АІЛ6МЕ0 

Некоторые не-АИЗ РогІН совместимые системы имеют ] вызывающее цикл компилятора 
в дополнение к установке ЗТАТЕ. Такая система неуместно пыталась бы 
компилировать второе использование МОР. 
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Также заметьте, что ничто в Стандарте не мешает программе искать идентификаторы 
исполнения ] или [ и использовать их для изменения ЗТАТЕ. Эти факты предлагают, 
что реализации ] будут делать только установку ЗТАТЕ и единственный цикл 
интерпретатора/компилятора будет контролировать ЗТАТЕ. 

А.6.1.2270 ТНЕМ 
Типичное использование: 

: X ... ІезІ ІР ... ТНЕМ ... ; 


или 




X . . . ТезТ ІР . . . ЕІ_5Е . . . ТНЕМ 


А. 6.1.2380 ІІМЮОР 
Типичное использование: 

: X ... 

Іітіі Тігзі: 

00 

. . . Іезі; ІР . . . ІІМІ.00Р ЕХІТ ТНЕМ 
І_00Р . . . 


ІІМЬООР позволяет использование ЕХІТ в пределах контекста, 00 . . . І_00Р и 
связанной сіо-іоор конструкции. ІІІ\ІІ_00Р как функция был назван ІІШО. ІІЫ ЬООР более 
выражает действие: ничто не отменяется - мы просто прекращаем делать это. 

А.6.1.2390 ІІІЧТИ- 
Типичное использование: 

: X . . . ВЕ6ІМ . . . ІѲ5І: ІІМТІІ_ ... ; 

А.6.1.2410 ѴАРІАВІ_Е 
Типичное использование: 

... ѴАРІАВІ_Е ХУ2 ... 

А.6.1.2430 ИННЕ 
Типичное использование: 

: X ... ВЕ6ІМ ... ТезТ ЫНІбЕ ... РЕРЕАТ ... ; 

А. 6.1.2450 ѴУОРО 
Типичное использование: 

сбаг ѴУОРО ссс<сбаг> 
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А.6.1.2500 [ 

Типичное использование: 

: X . . . [ 4321 ] 1_ІТЕВАІ_ ... ; 

А.6.1.2510 ['] 

Типичное использование: 

: X ... ['] пате ... ; 

См. : А.6.1.1550 РІШ. 

А.6.1.2520 [СНАР] 

Типичное использование: 

: X ... [СНАР] ссс ... ; 

А.6.1.2540 ] 

Типичное использование: 

: X . . . [ 1234 ] ІЛТЕРАІ. ... ; 

А.6.2 Расширения основных слов 

Слова в этой коллекции относятся к нескольким категориям: 

- Слова, которые находятся в общем использовании, но считаются менее 
обязательными чем Основные слова (например, Ѳ<>); 

- Слова, которые находятся в общем использовании, но могут быть тривиально 
определены из Основных слов (например, РАІ_5Е) ; 

- Слова, которые являются прежде всего полезными в узко определенных типах 
приложений или менее часто используются (например, РАРЗЕ); 

- Слова, которые осуждаются в пользу новых слов, представленных для решения 
специфических проблем (например, СОМѴЕРТ) . 



Из-за различия оснований для включения этих слов, Технический Комитет не 
поощряет разработчиков предлагать законченную коллекцию, но выбирать слова 
считающиеся наиболее ценными для их клиентуры. 

А.6.2.0060 #ТІВ 

Функция #ТІВ была заменена 501ІРСЕ. 

А.6.2.0200 .( 

Типичное использование: 

.( ссс) 

А.6.2.0210 .В 

В .В, "В" сокращение для ВІ6НТ . 

А.6.2.0340 2>В 

Исторически, 2>В использовался для реализации 00. Отсюда порядок параметров на 
стеке возвратов. 
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Основная польза 2>В в том, что оно помещает верхний элемент стека на вершину 
стек возвратов. Например, число две-ячейки может быть перемещено на стек 
возвратов и все еще иметь самую старшую ячейку доступной на вершине стека 
возвратов. 

А.6.2.0410 2В> 

Заметьте, что 2В> - не эквивалентен В> В>. Вместо этого, это отражает действие 
2В> (см. А.6.2.0340). 

А.6.2.0455 :І\ІОІ\ІАМЕ 

: ІМОІМАМЕ позволяет пользователю создавать идентификатор исполнения с семантикой 
определения через двоеточие без связанного имени. Ранее, только : (двоеточие) 
могло создавать идентификатор исполнения с этой семантикой. Таким образом, код 
РогТІі мог быть откомпилирован только, используя синтаксис :, так: 

: ІМАМЕ ... ; 

: ІМОІМАМЕ устраняет это ограничение и помещает компилятор РогТН в руки 
программиста. 

: ІМОІМАМЕ может использоваться для создания специфических для применения языков 
программирования. Одна методика - это смешать кодовые фрагменты РогТІі со 
специфическими для применения конструкциями. Специфические для применения 
конструкции используются : ІМОІМАМЕ для компиляции РогТб кода и сохранения 
соответствующего идентификатора исполнения в структурах данных. 

Функциональные возможности : ІМОІМАМЕ могут быть встроены в любую систему РогТН. 
Годами эксперты РогТІі программирования использовали детальное знание их систем 
для генерации безымянных фрагментов кода. Теперь эта функция была именована и 
может использоваться в переносимой программе. 

Например : ІМОІМАМЕ может использоваться для формирования таблицы кодовых 
фрагментов, где индексация в таблице позволяет выполнять специфический 
фрагмент. Синтаксис объявления таблицы: 

: ІМОІМАМЕ . . сосіе Тог соттапсі 0 . . ; 0 СМР ! 

: ІМОІМАМЕ . . сосіе Тог соттапсі 1 . . ; 1 СМР ! 

: ІМОІМАМЕ . . сосіе Тог соттапсі 99 . . ; 99 СМР ! 

... 5 СМР @ ЕХЕСІІТЕ . . . 

Определения таблицы, формирующей слова: 



СКЕАТЕ СМО-ТАВІ.Е \ таблица для команд идентификаторов исполнения 
100 СЕІ_І_5 АІ_І_0Т 

: СМО ( п -- а-асісіг ) \ энный адрес элемента в таблице 
СЕІ_І_5 СМ0-ТАВ1_Е + ; 

Как дальнейший пример, может быть создано определяющее слово, чтобы позволять 
контроль выполнения. В примере ниже подсчитывается число раз выполнения слова. 

: должен быть сначала переименован, чтобы позволить определение нового ; . 
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: 00 С 060 М ( -- ) 

\ Изменить созданное СРЕАТЕ слово, чтобы выполниться подобно 
\ определению двоеточия 

00Е5> ( і*х а-асісіг -- }*х ) 

1 ОѴЕР +! \ выполнение счетчика 

СЕІ_І_+ @ ЕХЕСІІТЕ \ выполнение :І\ЮМАМЕ определения 


: ОЮ: : ; \ только псевдоним 

0І_0: : ( "пате" -- а-асісіг хі соіоп-зуз ) 

\ начинает счетное-выполнение определения через двоеточие 
СКЕАТЕ НЕКЕ Ѳ , \ память для счетчика выполнения 

О , \ память для идентификатора исполнения 

00С0ЮМ \ установить время выполнения для созданного 

\ СРЕАТЕ слова 

:ШМАМЕ \ начать неименованное определение через двоеточие 


( Примечание размещения 00Е5>: 00ЕЗ> должно изменить созданное СРЕАТЕ 
слово а не :ШМАМЕ определение, так что 00Е5> должно выполниться 
прежде :М0МАМЕ.) 

ОЮ: ; ( а-асісіг хі соіоп-зуз -- ) 

\ заканчивает счетное-выполнение определения через двоеточие 

Р05ТР0МЕ ; \ завершает компиляцию определения через двоеточие 

5\л/АР СЕІ_І_+ ! \ сохраняет идентификатор исполнения 

; ІММЕОІАТЕ 

Новые : и ; используются точно так же как стандартные для определения слов: 

... : ххх ... ; ... ххх 

Теперь однако, эти слова можно "ІіскесІ", чтобы отыскать счетчик (и 
идентификатор исполнения): 

... ' ххх >В00У ? ... 

А.6.2.0620 700 

Типичное использование: 

: РАСТОРІАб ( +ПІ -- +п2 ) 1 ЗМАР 1+ 700 I * 1_00Р ; 

Это слово было добавлено в ответ на многие запросы для разрешения трудности 
внесенной РогІІі-83 словом 00, которое на 16-бит системе будет выполняться 
65,535 раз, если даны равные параметры. Так как этот Стандарт также поощряет 
32-разрядные системы, то это поведение может быть невыносимым. Технический 
Комитет рассмотрел применение этой семантики к 00, но отклонил на том 
основании, что это могло бы нарушить существующий код. 
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А.6.2.Ѳ7Ѳ0 АСАІІМ 
Типичное использование: 

: X ... ВЕСІІМ ... АСАІІМ ... ; 

Если последовательность слов не имеет способ закончиться, это бесконечный цикл. 

А.6.2.0855 С" 

Типичное использование: 

: X ... С" ссс" ... ; 

Просто преобразовать строки со счетчиком к указателю/длине, но трудно сделать 
наоборот. С" является единственным новым словом, которое использует 
представление стека "адрес строки со счетчиком". Оно предусмотрено как помощь 
перенесению существующих программ на АІМ5 Рогій системы. Относительно трудно 
реализовать С" в терминах других стандартных слов, рассматривая их семантику 
"компиляция строки в текущее определение". 

Пользователи С" поощряются к перемещению их прикладного кода к 
непротиворечивому использованию преимущественно "с-асісіг и" стекового 
представления с помощью дополнительного слова 5". Это может быть выполнено 
преобразованием прикладных слов с входными параметрами со строкой со счетчиком 
для использования преимущественно "с-асісіг и" представления, таким образом 
устраняя потребность в С". 

См.: 3.1.3.4 Строки со счетчиком. 

А.6.2.0873 САЗЕ 
Типичное использование: 

: X . . . 

САЗЕ 

1е5І:1 ОР . . . ЕШОР 
ТезТп ОР . . . ЕШОР 
... ( сІеТаиШ ) 

ЕШСА5Е . . . 


А.6.2.0945 СОМРШЕ, 

СОМРШЕ, - эквивалент ЕХЕСІІТЕ для компиляции. Во многих случаях возможно 
компилировать слово с использованием Р05ТР0ІМЕ без использования СОМРШЕ, . 
Однако использование Р05ТР0ІМЕ требует, чтобы имя слова было известно во время 
компиляции, тогда как СОМРШЕ, позволяет слову быть размещенным в любое время. 
В некоторых случаях возможно использовать ЕѴАШАТЕ для компиляции слова, чье 
имя не известно до времени выполнения. Это имеет две возможных проблемы: 

- ЕѴАШАТЕ медленнее чем СОМРШЕ, , потому что требуется поиск в словаре. 

- Текущий порядок поиска затрагивает результат, ЕѴАШАТЕ. 

В традиционных реализациях шитого кода, компиляция выполняется с помощью , 
(запятая). Это использование - не переносимое; это не работает для 
подпрограммного шитого кода, непосредственного кодирования, или перемещаемых 
реализаций. Использование СОМРШЕ, является переносимым. 
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В большинстве систем возможно реализовать СОМРШЕ, так, что оно сгенерирует код 
оптимизированный до той же самой степени как код сгенерированный нормальным 
процессом компиляции. Однако в некоторых реализациях есть два различных 
"идентификатора", соответствующих специфическому имени определения: нормальный 
"идентификатор исполнения", который используется при интерпретации или с 
ЕХЕСІІТЕ, , и "идентификатор компиляции", который используется при компиляции. И 
не всегда возможно получить идентификатор компиляции от идентификатора 
исполнения. В этих реализациях СОМРШЕ, не могло бы генерировать код являющийся 



столь же эффективным как обычно оттранслированная программа. 


А. 6.2.0970 СОІМѴЕРТ 

СОІМѴЕРТ может быть определено следующим образом: 

: СОІМѴЕРТ СНАР+ 65535 >І\ІІІМВЕК ОРОР ; 

А.6.2.1342 ЕШСА5Е 
Типичное использование: 

: X . . . 

САЗЕ 

1е5І:1 ОР . . . ЕШОР 
ТезТп ОР ... ЕШОР 
... ( сІеТаиН ) 

ЕШСА5Е ... 


А. 6.2.1343 ЕШОР 
Типичное использование: 

: X . . . 

САЗЕ 

Іезіі ОР ... ЕШОР 

ііезтп ор . . . ешор 
... ( сІеТаиН ) 
ЕШСА5Е ... 


А.6.2.1390 ЕХРЕСТ 

Спецификация положительного целочисленного счетчика (+п) для ЕХРЕСТ, позволяет 
некоторым разработчикам продолжать их практику использования нулевого или 
отрицательного значения как флага для вызова специального поведения. Поскольку 
такое поведение - вне Стандартного, Стандартные Программы не могут зависеть от 
этого, но Технический Комитет не желает этому излишне препятствовать. Так как 
фактические значения - почти всегда маленькие целые числа, никакие 
функциональные возможности не ослабляются этим ограничением. 
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А.6.2.1850 МАРКЕР 

Поскольку реализации словаря стали более сложными, и в некоторых случаях 
используют множественные адресные пространства, Р0Р6ЕТ стал предельно трудным 
или невозможным для реализации на многих системах РогІП. МАРКЕР очень ослабляет 
проблему, делая возможным для системы помнить "ориентирующую информацию" 
заранее, которая конкретно отмечает места, где словарь может быть перестроен в 
некотором будущем. 

А.6.2.1950 ОР 
Типичное использование: 

: X . . . 

САЗЕ 

Іезіі ОР . . . ЕШОР 
ТезТп ОР . . . ЕШОР 
... ( сІеТаиН ) 

ЕМРСАЗЕ . . . 


А.6.2.2000 РАО 

РАО была доступна как рабочая память для строк начиная с самых ранних РогІИ 
реализаций. Было доведено до нашего внимания, что много программистов 
отказываются от использования РАО, опасаясь несовместимости в системном 
использовании. РАО конкретно предназначен как удобство для программиста, однако 
мы документировали факт, что никакие стандартные слова не используют его. 



А.6.2.2008 РАРЗЕ 
Типичное использование: 

сііаг РАРЗЕ ссс<сИаг> 

Традиционное слово Рогіііі для синтаксического анализа это МОРО. РАРЗЕ решает 
следующие проблемы МОРО: 

а) МОРО всегда пропускает ведущие разделители. Это поведение соответствует 
использованию текстовым интерпретатором, который ищет последовательности 
непустых символов, но не соответствует для использования словами типа ( , .( , 
и . Рассмотрите следующее (испорченное) определение .( : 

: . ( [СНАР] ) МОКР СОІІМТ ТУРЕ ; ІММЕОІАТЕ 

Это работает прекрасно, когда используется в строке подобно: 

.( НЕІ_І_0 ) 5 . 

но рассмотрите то, что случается, если пользователь вводит пустую строку: 

.( ) 5 . 

Определение .( показанное выше обработало бы ) как ведущий разделитель, 
пропустило его, и продолжило потреблять символы, пока оно не обнаружило бы 
другой ) который следовал за не-) символом, или пока не опустела бы область 
анализа. В показанном примере 5 . было бы обработано как часть из строки, 
которая будет напечатана. 
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С РАРЗЕ, мы могли бы записать правильное определение .( : 

: .( [СНАР] ) РАР5Е ТУРЕ ; ІММЕОІАТЕ 

Это определение избегает аномалии "пустой строки". 

Ь) МОРО возвращает свой результат как строку со счетчиком. Это имеет четыре 
плохих эффекта: 

1) Символы принятые МОРО должны быть скопированы из входного буфера во 
временный буфер, чтобы создать место для символа счетчика, который должен быть 
в начале строки со счетчиком. Шаг копирования неэффективен в сравнении с РАР5Е, 
который оставляет строку во входном буфере и не должен копировать ее куда- 
нибудь . 

2) МОРО должно быть внимательным, чтобы не сохранить слишком много символов во 
временный буфер, и таким образом не перезаписать кое-чего вне конца буфера. Это 
добавляется к накладным расходам из шага копирования. (МОРО, вероятно, придется 
просматривать много символов перед поиском конечного разделителя.) 

3) Символ счетчика ограничивает длину строки, возвращаемой МОРО до 255 символов 
(более длинные строки могут легко быть сохранены в блоках!). Это ограничение не 
существует для РАРЗЕ. 

4) Временный буфер типично перезаписывается следующим использованием МОРО. Это 
создает временную зависимость; значение, возвращенное МОРО допустимо только для 
ограниченной продолжительности. РАРЗЕ также имеет временную зависимость 
связанную с продолжительностью жизни входного буфера, но это менее серьезно в 
большинстве случаев, чем временная зависимость МОРО. 

Поведение МОРО относительно пропуска ведущих разделителей полезно для 
синтаксического анализа ограниченных пробелом имен. Много системных реализаций 
включают дополнительное слово для этой цели, подобное РАРЗЕ относительно 



возвращаемого значения "с-асісіг и", но без явного параметра разделителя (набор 
разделителей - неявно "пробельные символы"), и который пропускает ведущие 
разделители. Обычное описание для этого слова: 

РАРЗЕ-МОРЭ ( "<зрасе5>пате" -- с-асісіг и ) 

Пропускает ведущие пробелы и выделяет имя ограниченное пробелом, с-асісіг - адрес 
в пределах входного буфера и и - длина выбранной строки. Если область анализа 
пуста, результирующая строка имеет нулевую длину. 

Если и РАР5Е и РАРЗЕ-МОРЭ присутствуют, потребность в ѴУОРО в значительной 
степени устранена. 

А.6.2.2030 РІСК 

0 РІСК эквивалентно ОІІР, и 1 РІСК эквивалентно ОѴЕР. 

А. 6.2.2040 фІІЕРѴ 

Функция фІІЕРѴ может быть выполнена с АССЕРТ и ЕѴАШАТЕ . 
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А.6.2.2125 РЕРІШ 

Это слово - полезное обобщение фІІЕРѴ. Переопределение фІІЕРѴ для выполнения этой 
спецификации сломала бы существующий код. РЕРІШ разработан, чтобы вести себя 
разумно для всех возможных входных источников. Если входной источник исходит от 
пользователя, как с фІІЕРѴ, РЕРІІШ может все еще возвращать значение Таізе если, 
например, канал связи закрыт, так чтобы система знала, что ввод больше не будет 
доступен. 

А.6.2.2150 РОШ 

2 РОШ эквивалентно РОТ, 1 РОІ_І_ эквивалентно 5Ѵ\/АР, и 0 Р01_І_ - пустая операция. 
А. 6.2.2182 5АѴЕ-ІМРІІТ 

5АѴЕ-ІИРІІТ и РЕ5Т0РЕ- ІМРІІТ позволяют ту же самую степень переустановления 
входного источника в пределах текстового файла, как это доступно с В1_0СК 
вводом. 5АѴЕ-ІМРІІТ и РЕ5Т0РЕ- ІМРІІТ "скрывают подробности" операций, необходимых 
для совершения этого переустановления, и используются одинаковым способом со 
всеми входными источниками. Это упрощает переустановку входного источника для 
программ, потому что они не должны проверять несколько переменных и 
предпринимать различные действия в зависимости от значений этих переменных. 

5АѴЕ-ІИРІІТ и РЕ5Т0РЕ- ІМРІІТ предназначены для переустановления в пределах одного 
входного источника; например, следующий сценарий НЕ позволяется для Стандартной 
Программы: 


XX 

ЗАѴЕ-ІИРІІТ СРЕАТЕ 
5" РЕ5Т0РЕ- ІМРІІТ" ЕѴАШАТЕ 
АБОРТ" соиісіп'1: гезіоге іприі" 


Это неправильно, потому что во время выполнения РЕ5Т0РЕ-ІМРІІТ входной источник 
- строка через ЕѴАШАТЕ, которая - не тот же самый входной источник, который 
был в действительности, когда было выполнено ЗАѴЕ-ІМРІІТ . 

Следующий код позволяется: 

: XX 

5АѴЕ-ІМРІІТ СРЕАТЕ 
5" .( Неііо)" ЕѴАШАТЕ 

РЕ5Т0РЕ- ІМРІІТ АБОРТ" соиісіп 1 1 гезіоге іприі;" 



После возвращения из ЕѴАШАТЕ, спецификация входного источника восстановлена к 
ее предыдущему состоянию, таким образом 5АѴЕ-ІМРІІТ и ПЕ5Т0ПЕ- ІМРІІТ вызваны 
действительно с одним и тем же входным источником. 

В вышеупомянутых примерах, ЕѴАШАТЕ фраза могла быть заменена фразой включающей 
ІІ\ІСІ_ІЮЕ-РІІ_Е, и применились бы те же самые правила. 

Стандарт не определяет то, что случается, если программа нарушает 
вышеупомянутые правила. Стандартная Система могла бы проверять нарушение и 
возвращать индикацию исключения из ПЕ5Т0РЕ- ІМРІІТ, или она могла бы терпеть 
неудачу непредсказуемым способом. 
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Возвращаемое значение из РЕ5Т0КЕ- ІМРІІТ прежде всего предназначено для сообщения 
о случае, где программа пытается восстановить позицию входного источника, чья 
позиция не может быть восстановлена. Таким входным источником могла бы быть 
клавиатура. 

Вложение 5АѴЕ-ІМРІІТ и ПЕ5Т0РЕ- ІМРІІТ позволяется. Например, следующая ситуация 
работает как ожидается: 

: XX 

5АѴЕ-ІМРІІТ 

5" Т1" ІІМСШШЕО 
\ ТПе Тііе "Т1" іпсіисіез: 

\ ... ЗАУЕ-ІИРШ . . . РЕЗТОРЕ-ІИРІІТ . . . 

\ ЕпсІ оТ Тііе "Т1" 

РЕ5Т0РЕ- ІИРІІТ АВОРТ" соиісіп ' Т гезіоге іприі;" 


В принципе, РЕЗТОРЕ- ІМРІІТ могло быть реализовано как "всегда сбой", например: 

: РЕ5Т0РЕ- ІИРІІТ ( хі ... хп п -- Тіад ) 

0 ?Р0 ОРОР 1_00Р ТРІІЕ 


Такая реализация не была бы полезна в большинстве случаев. Было бы 
предпочтительнее для системы скорее оставить 5АѴЕ-ІИРІІТ и РЕ5Т0РЕ-ІМРІІТ 
неопределенными, чем создавать бесполезную реализацию. В отсутствии слов, 
прикладной программист может выбирать, действительно ли создавать "фиктивные" 
реализации или обойти проблему некоторым другим путем. 

Примеры того, как реализация могла бы использовать возвращаемые значения из 
5АѴЕ-ІИРІІТ для выполнения функции сохранения/восстановления: 


Входной источник 

возможные значения стека 

блок 

>ІМ @ 

ВІ_К § 2 

ЕѴАШАТЕ 

>ІМ § 

1 

клавиатура 

>ІМ § 

1 

текстовый файл 

>ІМ @ 

ІО - р05 І1І-р05 3 


Это только примеры; Стандартная Программа не предполагает какое либо конкретное 
значение для отдельных элементов стека, возвращаемых 5АѴЕ-ІМРІІТ. 

А.6.2.2290 ТІВ 

Функция ТІВ была заменена 501ІКСЕ. 
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А.6.2.2295 ТО 

Исторически, некоторые реализации ТО не имеют явного выделения имени. Вместо 
этого они устанавливают флаг режима, который проверяется последующим 
выполнением имени. А№ РогШ явно требует, чтобы ТО выделял имя, так чтобы 
эффект ТО был предсказуем, когда он используется в конце области анализа. 

Типичное использование: 
х ТО пате 

А.6.2.2298 ТКІІЕ 

ТПІІЕ эквивалентно фразе О Ѳ=. 

А. 6.2.2405 ѴАШЕ 
Типичное использование: 

О ѴАШЕ РАТА 

: ЕХСНАМ6Е ( пі - - п2 ) ОАТА 5Ѵ\/АР ТО ОАТА ; 

ЕХСНАМ6Е оставляет пі в ОАТА и возвращает предшествующее значение п2. 

А.6.2.2440 (л/ІТНІЫ 

Мы описываем МІТНІМ без упоминания кругового числового пространства 
(неопределенный термин) или предоставления кода. Вот - числовая строка с точкой 
переполнения (о) в крайнем правом положении и точкой антипереполнения (и) в 
крайнем левом: 

и.о 

Есть два случая для рассмотрения: либо диапазон п2|и2..пЗ|иЗ охватывает точки 
переполнения/антипереполнения, либо нет. Позвольте исследовать сначала не 
охватывающий случай: 

и.[.).о 

[ обозначает п2|и2, ) обозначает пЗ|иЗ, и точки и [ - это числа В ПРЕДЕЛАХ 
(МІТНІІМ) диапазона. пЗ|иЗ больше чем п21и2, так что следующие проверки 
определят, является ли п1|и1 В ПРЕДЕЛАХ (МІТНІІМ) п2|и2 и пЗІиЗ: 

п2|и2 < п1|и1 и п1|и1 < пЗ|иЗ. 

В случае, где диапазон сравнения колеблется между точками 
переполнения/антипереполнения: 

и.).[.о 

пЗ|иЗ - меньше чем п2|и2, и следующие проверки определят, является ли п1|и1 В 
ПРЕДЕЛАХ (ѴЯТНІІЧ) п21 и2 и пЗ|иЗ: 

п2|и2 < п1[и1 или п!|и1 < пЗ|иЗ. 
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МІТНІМ должен работать для знаковых и без знаковых параметров. Одна очевидная 
реализация не работает: 

: МІТНІМ ( Іезі; Іом Підй -- "Лад ) 

>Р ОѴЕР < 0= ( Ііезі; Ладі ) 5\л/АР Р> < ( Паді Пад2 ) АМР 


Примите арифметику дополнительного кода (дополнение до двух) на 16-бит машине, 
и рассмотрите следующую проверку: 










33000 32000 34000 (л/ІТНІЫ 

Вышеупомянутая реализация возвращает 'Гаізе для этой проверки, даже притом, что 
число без знака 33000 - ясно в пределах диапазона {{32000 .. 34000}}. 

Проблема состоит в том, что на неправильной реализации, знаковое сравнение < 
дает неправильный ответ, когда 32000 сравнивается с 33000, потому что когда эти 
числа рассматриваются как числа со знаком, 33000 рассматривается как 
отрицательное 32536, в то время как 32000 остается положительным. 

Замена < на ІІ< в вышеупомянутой реализации заставляет ее работать с числами без 
знака, но вызывает проблемы с некоторыми диапазонами чисел со знаком; в 
частности испытание: 

1-5 5 (л/ІТНІЫ 

дало бы неправильный ответ. 

Для машин с дополнительным кодом (дополнение до двух), которые игнорируют 
арифметическое переполнение (большинство машин), следующая реализация работает 
во всех случаях: 

: (л/ІТНІИ ( Іезі; Іои йідй -- Пад ) ОѴЕК - Ж - Р> ІІ< ; 

А.6.2.2530 [СОМРШЕ] 

Типичное использование: 

: паше2 . . . [СОМРШЕ] патеі ... ; ІММЕОІАТЕ 

А.6.2.2535 \ 

Типичное использование: 

5 С0И5ТАІМТ ТНАТ \ЭТО - КОММЕНТАРИЙ О ТНАТ 

А.7 Дополнительный Блочный набор слов 

Ранние системы РогИп выполнялись автономно, без ведущей 05. Блоки 1024 байт 
были разработаны как удобный элемент диска, и большинство автономных систем 
РогИп все еще используют их. Это относительно простой для записи 
непосредственный дисковый драйвер, который отображает адреса 
головка/дорожка/сектор на номера блоков. Такие дисковые драйверы чрезвычайно 
быстры по сравнению с обычными файл-ориентированными операционными системами, и 
защита высока, потому что нет никого доверия до карты диска. 
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Сегодня много реализаций РогІІі выполняются под ведущими операционными 
системами, потому что совместимость, которую они предлагают пользователю, 
перевешивает ухудшение производительности. Много людей использующих такие 
системы предпочитают использовать только файлы ведущей 05; однако люди, которые 
используют, автономные и не автономные Рог*:Іі нуждаются в совместимом способе 
доступа к диску. Блочный набор слов включает наиболее общие слова для доступа к 
источнику программы и данным на диске. 

Чтобы гарантировать, что Стандартные Программы, нуждающиеся в доступе к 
запоминающему устройству, имеют механизм соответствующий автономным и не 
автономным реализациям, АМ5 РогИп требует, что бы Блочный набор слов был 
доступен, если предусмотрены любые средства запоминающего устройства. На не 
автономных реализациях, блоки обычно находятся в файлах ведущей 05. 

А.7.2 Дополнительные термины 


блок 

Много систем РогІН используют блоки, чтобы содержать источник программы. 



Традиционно такие блоки форматированы для редактирования как 16 строк по 64 
символа. Исходные блоки часто упоминаются как "экраны". 

А.7.6 Словарь 


А.7.6.2.2190 5СК 

5СП сокращение для экрана. 

А.8 Дополнительный набор слов двойных чисел 

Системы Рог^б на 8-бит и 16-бит процессорах часто находят необходимым иметь 
дело с числами двойной-длины. Но много РогСН на маленьких внедренных системах 
не желают, и много пользователей Рогіііі на системах с размером ячейки 32-бит или 
больше находят, что потребность в числах двойной длины очень незначительная. 
Поэтому мы выделили слова, которые управляют объектами двойной длины в этот 
дополнительный набор слов. 

Пожалуйста заметьте, что соглашение об именах, используемое в этом наборе слов 
передает некоторую важную информацию: 

1. Слова, чьи имена имеют форму 2ххх, имеют дело с парой-ячеек, где отношения 
между ячейками не определено. Они могут быть двумя векторами, числами двойной 
длины, или любой парой ячеек, которыми удобно манипулировать вместе. 

2. Слова с именами формы Оххх имеют дело определенно с целыми числами двойной 
длины. 

3. Слова с именами формы Мххх имеют дело с некоторой комбинацией одинарных и 
двойных целых чисел. Порядок, в котором они появляются на стеке, определен 
давней общей практикой. 

Обратитесь к А.3.1 для обсуждения типов данных в Рог^П. 

А.8.6 Словарь 
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А. 8.6.1.0360 2С0М5ТАІМТ 
Типичное использование: 

хі х2 2С0М5ТАІМТ пате 

А.8.6.1.0390 2ІЛТЕИАІ. 

Типичное использование: 

: X . . . [ хі х2 ] 2І_ІТЕПАІ_ ... ; 

А.8.6.1.0440 2ѴАРІАВЦЕ 
Типичное использование: 

2ѴАПІАВІ_Е пате 

А.8.6.1.1070 О.П 
В О.П, "Н" сокращение для ПІ6НТ . 

А.8.6.1.1090 02* 

См.: А.6.1.0320 2* для соответствующего обсуждения. 

А.8.6.1.1100 02/ 

См.: А.6.1.0330 2/ для соответствующего обсуждения. 

А.8.6.1.1140 0>5 

Существуют представления чисел, например представление величины со знаком, где 
сокращение от двойной к одинарной точности не может быть сделано просто с 
помощью ОРОР. Это слово, эквивалентное ОПОР на системах с дополнительным кодом 
(дополнение до двух), уменьшает чувствительность кода приложения к 



представлению чисел и облегчает переносимость. 

А.8.6.1.1820 МѴ 

М*/ было однажды описано Сйиск Мооге как наиболее полезный арифметический 
оператор в РогІИ. Оно является главной рабочей лошадкой в большинстве 
вычислений, вовлекающих числа две-ячейки. Заметьте, что некоторые системы 
разрешают знаковые делители. Это может много стоить в производительности на 
некоторых СРІІз . Не доказано, что требование положительного делителя - это 
проблема. 


А.8.6.1.1830 М+ 

М+ - это классический метод для интегрирования. 

А.9 Дополнительный набор слов исключений 

САТОН и ТНРОМ предусматривают надежный механизм для обработки исключительных 
ситуаций, без того чтобы иметь необходимость размножать флаги исключения через 
многочисленные уровни вложения слова. Это подобно основной тенденции механизмов 
"нелокального возвращения" многих других языков, типа С зе1:]тр() и 1опд]тр(), 
и І_І5Р САТСН и ТИРОМ. В контексте Рогій, ТИРОМ может быть описано как 
"многоуровневый ЕХІТ" с САТСН, отмечающим местоположение, к которому ТИРОМ 
может возвращаться. 
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Немного подобные "многоуровневые ЕХІТ" Рогій схемы обработки особых ситуаций 
были описаны и использовались в прошлые годы. Не возможно осуществить такую 
схему, используя только стандартные слова (иные, чем САТСН и ТНРОМ), потому что 
нет никакого переносимого способа "отмотать" стек возвратов к предопределенному 
месту. 

ТНРОМ также предоставляет удобную методику реализации для стандартных слов 
АВОРТ и АВОРТ", позволяя приложению определять, с помощью использования САТСН, 
поведение при событии системного АВОРТ. 


Эта типовая реализация САТСН и ТНРОМ использует нестандартные слова, описанные 
ниже. Они или их эквиваленты доступны во многих системах. Другие стратегии 
реализации, включающие непосредственное сохранение значения ОЕРТН возможны, 
если такие слова не доступны. 


5Р@ ( -- асісіг ) возвращает адрес, соответствующий вершине стека данных. 

ЗР! ( асісіг -- ) устанавливает указатель стека на асісіг, таким образом 

восстанавливая глубину стека на ту же самую глубину, которая существовала как 
раз перед тем как был получен асісіг выполнением 5Р@. 

РР@ ( -- асісіг ) возвращает адрес, соответствующий вершине стека возвратов. 

РР! ( асісіг -- ) устанавливает указатель стека возвратов на асісіг, таким образом 

восстанавливая глубину стека возвратов на ту же самую глубину, которая 
существовала как раз перед тем как был получен асісіг выполнением РР@. 


ѴАРІАВЙЕ НАІ\Ю1_ЕР О НАІ\Ю1_ЕР ! \ последний обработчик особых ситуаций 


САТСН ( хі -- 
5Р@ >Р 
НА1\Ю1_ЕР § >Р 
РР@ НАШІ.ЕР ! 
ЕХЕСІЯЕ 
Р> НАІ\ЮІ_ЕР ! 
Р> ЭРОР 
0 


ехсерііоп# | 0 ) \ возвращает асісіг на стеке 
( хі ) \ сохраняет указатель вершины стека данных 
( хі ) \ и предыдущий обработчик 
( хі ) \ устанавливает текущий обработчик 
( ) \ выполняет возврат если не ТНРОМ 

( ) \ восстанавливает предыдущий обработчик 

( ) \ удаляет сохраненный стек ріг 

( 0 ) \ нормальное завершение 



ТНРОМ ( ??? ехсерііоп# -- ??? ехсерііоп# ) 

( ехс# ) \ Ѳ ТНРОМ - пустая команда 
( ехс# ) \ восстанавливает предыд. стек возвратов 
( ехс# ) \ восстанавливает предыд. обработчик 
( заѵесі-зр ) \ ехс# на стеке возвратов 
( ехс# ) \ восстановление стека 
\ Возвращение к программе вызвавшей САТСН, потому что стек 
\ возвратов 

\ восстановлен к состоянию, которое существовало 
\ когда САТСН начал выполнение 
ТНЕІМ 


701ІР ІР 

НАІМОІ_ЕР § РР 
Р> НАІМОІ.ЕР ! 
Р> 5Ѵ\/АР >Р 
5Р! ЭРОР Р> 


В многозадачной системе, переменная НАШІ.ЕР должна быть переменной в в-задачной 
области (то есть, пользовательская переменная). 
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Эта типовая реализация не обрабатывает явно случай, в котором САТСН никогда не 
вызывается (то есть, поведение АВОРТ). Одно решение состоит в том, чтобы 
добавить следующий код после ІР в ТНРОМ: 

НАШІ.ЕР § 0= ІР ( освободить стек ) діІІТ ТНЕІМ 

Другое решение состоит в том, чтобы выполнить САТСН в пределах (^ШТ так, чтобы 
был всегда в наличии "обработчик особых ситуаций последнего средства". 

Например: 


(ДЯТ 

( освободить стек возвратов и ) 

( установить входной источник на пользовательское устройство ввода 
данных ) 

Р05ТР0ІМЕ [ 

ВЕ6ІМ 

РЕРІІ_І_ 

1і/НИЕ 

[ ' ] ІІМТЕРРРЕТ САТСН 
САЗЕ 

0 ОР 5ТАТЕ § Ѳ= ІР ." ОК" ТНЕІМ СР ЕШОР 
-1 ОР ( Прервано ) ЕШОР 

-2 ОР ( отображает сообщение от АВОРТ" ) ЕШОР 
( по умолчанию ) ОІІР ." Ехсерііоп # " 

ЕМРСАЗЕ 
РЕРЕАТ ВУЕ 


Этот пример предполагает существование системной реализации слова ІІМТЕРРРЕТ, 
которое воплощает семантику текстового интерпретатора, описанную в 3.4 
Интерпретатор текста РогТІл . Заметьте, что эта реализация (^ШТ автоматически 
обрабатывает освобождение стека и стека возвратов, из-за свойственного ТНРОМ 
восстановления стеков данных и возвратов. Данным этим определением діІІТ, 
просто определить: 

: АВОРТ -1 ТНРОМ ; 

В системах с другими стеками в дополнение к стекам данных и возвратов, 
реализации из САТСН и ТНРОМ должны также сохранять и восстанавливать эти 
указатели вершин стеков. Такая "расширенная версия" может быть надстроена 
сверху этой основной реализации. Например, с другим указателем вершины стека 
доступным с помощью РР@ и РР! должен быть переопределен только САТСН: 


САТСН ( хі -- ехсерііоп# | 0 ) 



РР@ >Р САТСН Р> ОѴЕР ІР РР! ЕІ.5Е РРОР ТНЕМ ; 


В этом случае нет необходимости, ни в каких изменениях ТИРОМ. Заметьте что, как 
со всеми переопределениями, переопределенная версия САТСН будет доступна только 
определениям, откомпилированным после переопределения САТСН. 

САТСН и ТНРОМ предоставляют удобный путь для реализаций "очистки" состояния 
открытых файлов, если исключение происходит в течении интерпретации текстового 
файла с помощью ІІ\ІСІ_ІЮЕ-РІІ_Е . Реализация ІІ\ІСІ_ІЮЕ-РІІ_Е может предохранять (с 
САТСН) слово, которое исполняет текстовую интерпретацию, и если САТСН 
возвращает код исключения, файл может быть закрыт и исключение переброшено 
(геТНРОМп) так, чтобы файлы, включаемые во внешнем уровне вложенности, могли 
быть также закрыты. 
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Заметьте, что Стандарт позволяет, но не требует от ІІ\ІСІ_ІЮЕ-РІІ_Е закрывать его 
открытые файлы, если происходит исключение. Однако он требует от ІІ\ІСІ_ІЮЕ-РІІ_Е 
понизить уровень вложения спецификации входного источника, если исключение 
обработано ТНРОМ. 

А.9.3 Дополнительные условия применения 

Одно важное использование обработчика особых ситуаций - это поддержание 
управления программой под многими условиями, которые вызывают АБОРТ. Это 
реально только, если зарезервирован диапазон кодов. Заметьте, что приложение 
может перезагружать много стандартных слов таким способом, чтобы ТИРОМ 
неопределенные ситуации не нормальным образом обрабатывались с помощью ТИРОМ 
специфической системой. 

А.9.3.6 Обработка особых ситуаций 

Метод выполнения этой связи зависящий от реализации. Например, 1_0А0 может 
"знать" о САТСН и ТИРОМ (используя САТСН самостоятельно, например), или САТСН и 
ТНРОМ могут "знать" о 1_0А0 (поддерживая информацию вложенности входного 
источника в структуре данных известной в ТНРОМ, например). При этих 
обстоятельствах не возможно для стандартной Программы определить слова типа 
!_0А0 полностью переносимым способом. 

А.9.6 Словарь 

А.9.6.1.2275 ТНРОМ 

Если ТНРОМ выполнено с не нулевым параметром, эффект такой, как будто это 
возвратило соответствующее САТСН . В том случае глубина стека такая же, какая 
она была как раз перед началом выполнения САТСН . Значения параметров стека і*х 
могли изменяться произвольно в течение выполнения хі . Вообще, ничего полезного 
не может быть сделано с этими элементами стека, но так как их число известно 
(потому что глубина стека детерминирована), приложение может ОРОР их, чтобы 
возвратиться к предсказуемому состоянию стека. 

Типичное использование: 

: соиІсІ-ТаіІ ( -- сПаг ) 

КЕУ РІІР [СНАР] <2 = ІР 1 ТНРОМ ТНЕМ ; 

: сіо-іі ( а Ь -- с) 20Р0Р соиІсІ-ТаіІ ; 

: 1гу-і1 ( --) 

1 2 [' ] сіо-іі САТСН ІР 

( хі х2 ) 20Р0Р ." Было исключение" СР 
ЕІ_5Е ." Был символ " ЕМІТ СР 
ТНЕМ 



геігу-іі; ( -- ) 

ВЕ6ІМ 1 2 ['] сіо-іі; С АТОН ИННЕ 

( хі х2) 20Р0Р Исключение, пробуем продолжать" СР 
РЕРЕАТ ( сйаг ) 

." Был символ " ЕМІТ СР 
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А.10 Дополнительный сервисный набор слов 
А.10.6 Словарь 


А.10.6.1.0742 АТ-ХУ 

Большинство разработчиков поставляют метод позиционирования курсора на экране 
ОРТ, но есть большое разногласие в именах и параметрах стека. Эта версия 
поддерживается, по крайней мере, одним главным поставщиком. 

А.10.6.1.1755 КЕУ? 

Технический Комитет ходил по кругу некоторое время по поводу стекового эффекта. 
Любое решение нарушит чью-то практику и накажет некоторую машину. Этот путь не 
касается опережающего ввода с клавиатуры на некоторых системах, когда требуется 
реализация односимвольного буфера на машинах, где опрос клавиатуры неизбежно 
оканчивается разрушением символа. 

Использование КЕУ или КЕУ? указывает, что приложение не желает беспокоиться о 
не символьных событиях, так что они отвергаются в ожидании, в конечном счете, 
получения допустимого символа. Приложения, желающие обработать не символьные 
события, должны использовать ЕКЕУ и ЕКЕУ?. Возможно смешивать использование 
КЕУ? / КЕУ и ЕКЕУ? / ЕКЕУ в пределах отдельного приложения, но приложение 
должно использовать КЕУ? и КЕУ только, когда оно желает удалить не символьные 
события до получения допустимого символа. 

А.10.6.2.1305 ЕКЕУ 

ЕКЕУ предоставляет стандартное слово для обращения к зависимому от системы 
набору "необработанных" событий клавиатуры, включая события соответствующие 
членам стандартного набора символов, события соответствующие другим членам 
определенного реализацией набора символов, и нажатия клавиш которые не 
соответствуют членам набора символов. 

ЕКЕУ не предполагает никакого специфического числового соответствия между 
специфическими значениями кода события и значениями, представляющими 
стандартные символы. На некоторых системах, оно может допускать две отдельные 
клавиши, которые соответствуют одному и тому же стандартному символу, которые 
нужно отличить друг от друга. 

В системах, которые объединяют события клавиатуры и мыши в один "поток 
событий", единственное число, возвращенное ЕКЕУ, может быть неадекватно для 
представления полного диапазона возможного ввода. В таких системах, отдельная 
"запись события" может включать временную отметку, х,у координаты позиции мыши, 
состояния клавиатуры, и состояния кнопок мыши. В таких системах могло бы быть 
соответствующее ЕКЕУ для возвращения адреса "записи события" из которой могла 
быть извлечена другая информация. 

Также рассмотрите гипотетическую систему Рогій, выполняющуюся под М5-005 на РС 
совместимом компьютере. Предположите, что набор символов определенный 
реализацией - "нормальный" РС 8-бит набор символов. В этом наборе символов коды 
от 0 до 127 соответствуют А5СІІ символам. Коды от 128 до 255 представляют 
символы из различных не английских языков, математические символы, и некоторые 
графические символы, используемые для рисования в строке. В добавление к этим 
символам, клавиатура может генерировать различные другие "скэн-коды", 
представляющие такие не символьные события как клавиши курсора и функциональные 



клавиши. 
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Могут быть составные клавиши, с различными скэн-кодами, соответствующими одному 
и тому же стандартному символу. Например, символ представляющий число "1" часто 
появляется в строке цифровых клавиш выше алфавитных клавиш, и также в отдельной 
цифровой клавиатуре. 

Когда программа опрашивает операционную систему М5-005 для события клавиатуры, 
она получает единственный ненулевой байт представляющий символ, или нулевой 
байт, сопровождаемый байтом "скэн-кода", представляющим не символьное событие 
клавиатуры (например, функциональная клавиша). 

ЕКЕУ представляет каждое событие клавиатуры скорее как отдельное число, чем как 
последовательность чисел. Для системы описанной выше, следующее было бы 
разумной реализацией ЕКЕУ и связанных слов: 

Запрос к окружению МАХ-СНАР возвратил бы 255. 


Предположите существование слова 003-КЕУ ( -- сбаг ) которое выполняет 
системный вызов М5-Р05 "Прямой Ввод ЗТРІІМ" (Прерывание 216, Функция 076) и 
слово 003-КЕУ? ( -- Тіад) которое выполняет системный вызов М5-005 "Проверка 
Состояния ЗЮИМ" (Прерывание 216, Функция ѲВб). 

: ЕКЕУ? ( -- -Лад ) 003-КЕУ? Ѳ<> ; 

: ЕКЕУ ( -- и ) 003-КЕУ ?01ІР 0= ІР 003-КЕУ 256 + ТНЕІЧ ; 


ЕКЕУ>СНАР ( и 
ОІІР 255 > ІР 
ОІІР 259 = ІР 

ОРОР 0 ТРІІЕ ЕХІТ 
ТНЕІМ РАЦЗЕ ЕХІТ 
ТНЕІМ ТРІІЕ 


--и Таізе | сбаг Ігие ) 

( и ) 

\ 259 это С1г1-@ (АЗСII N111.) 
\ если так - замена символом 
\ иначе расширенный символ 
\ нормальный символ А5СІІ. 


ѴАРІАВЦЕ РЕШІІМ6-СНАР -1 РЕІМ0ІІМ6-СНАР ! 

: КЕУ? ( -- Тіад ) 

РЕІМ0ІІМ6-СНАР § 0< ІР 
ВЕ6ІІМ ЕКЕУ? ИННЕ 
ЕКЕУ ЕКЕУ>СНАР ІР 

РЕШІ^-СНАР ! ТРІІЕ ЕХІТ 
ТНЕІМ ОРОР 

РЕРЕАТ РАЦЗЕ ЕХІТ 
ТНЕІМ ТРІІЕ 


КЕУ ( -- сбаг ) 

РЕШІІМ6-СНАР § 0< ІР 

ВЕ6ІІМ ЕКЕУ ЕКЕУ>СНАР 0= ЫНШЕ 
ОРОР 

РЕРЕАТ ЕХІТ 

ТНЕІМ РЕІМ0ІІМ6-СНАР § -1 РЕІ\ЮІІ\І6-СНАР ! 
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Это - полнофункциональная реализация, предоставляющая прикладной программе 
простой путь, или обрабатывать не символьные события (с помощью ЕКЕУ), или 
игнорировать их и только рассматривать "реальные" символы (с помощью КЕУ). 



Заметьте, что ЕКЕУ отображает окон-коды от 0 до 255 в числа от 256 до 511. ЕКЕУ 
отображает число 259, представляя комбинацию клавиатуры Сбгі-Збібб-® в символ, 
чье числовое значение - 0 (АЗСІІ N116). Много АЗСІІ клавиатур генерируют А5СІІ 
N116 для Сбгі-Збібб-®, так что мы используем эту комбинацию клавиш для АЗСІІ N616 
(который иначе недоступен из МЗ-005, потому что нулевой байт показывает, что 
следует другой байт скэн-кода). 

Одно следствие использования системного вызова "Прямого Ввода ЗЮІ^' (функция 
7) вместо системного вызова "Ввода ЗЮІ^' (функция 8) - это что нормальное 
поведение 005 "прерывания Сбгі-С" - заблокировано, когда система ожидает ввода 
(С6г1-С все еще вызвало бы прерывание, пока символы выводятся). С другой 
стороны, если системный вызов "Ввод ЗЮІ^' (функция 8) использовался для 
реализации ЕКЕУ, Сбгі-С прерывание было бы доступно, но Сбгі-Збібб-® также 
вызвало бы прерывание, потому что операционная система обработает второй байт 
из 0,3 последовательности как Сбгі-С даже притом, что эти 3 - действительно 
скэн-код, а не символ. Одно решение "лучшее из обоих миров" - это использовать 
функцию 8 для первого байта получаемого ЕКЕУ, и функцию 7 для байта скэн-кода. 
Например: 

: ЕКЕУ ( -- и ) 

ООЗ-КЕУ-РбШСТ^-8 7Р6ІР 0= ІР 
005-КЕУ-Р6^СТ^-7 Р6ІР 3 = ІР 

ОРОР 0 Е65Е 256 + 

ТНЕN 

ТНЕN 


Конечно, если разработчик Рогбб выбирает передачу С6г1-С через программу, без 
использования ее обычной функции обработки прерывания, тогда функция 7 003 
соответствует обоим случаям (и некоторая дополнительная забота должна быть 
предпринята для предотвращения опережающего ввода с клавиатуры Сбгі-С от 
прерывания системы Рогбб в течение операций вывода). 

Система Рогбб могла бы также выбирать более простую реализацию КЕУ, без 
реализации ЕКЕУ, следующим образом: 

: КЕУ ( -- сбаг ) 005-КЕУ ; 

: КЕУ? ( -- -Гіад ) 005-КЕУ? Ѳ<> ; 

Недостатки более простой версии: 

a) Прикладная программа, которая использует КЕУ, ожидая получения только 
допустимых символов, могла бы получить последовательность байт (например, 
нулевой байт, сопровождаемый байтом с таким же числовым значением как у символа 
"А") которая, кажется, содержит допустимый символ, даже притом, что 
пользователь нажал клавишу (например, функциональная клавиша 4) которая не 
соответствует никакому допустимому символу. 

b) Прикладная программа, которая желает обработать не символьные события, будет 
должна выполнить КЕУ дважды, если она возвращает нуль первый раз. Это, могло бы 
казалось, быть разумной и простой для воплощения вещью. Однако, такой код - не 
переносимый на другие системы, которые не используют нулевой байт как "езсаре" 
код. 
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Используя подход ЕКЕУ, алгоритм для обработки событий клавиатуры может быть 
один и тот же для всех систем; системные зависимости могут быть уменьшены до 
таблицы или набора списка констант системно зависимых кодов клавиш используемых 
для доступа к специфическим прикладным функциям. Без ЕКЕУ алгоритм, не только 
таблица, вероятно будет системно зависимым. 



Другой подход к ЕКЕУ на М5-Р05 состоит в том, чтобы использовать функцию ВІ05 
"РеасІ КеуЬоагсІ ЗБаІіііз" (Прерывание 166, Функция 016) или связанную функцию 
"Сбеск КеуЬоагсІ" (Прерывание 16Ь, Функция 11Ь). Преимущество этой функции 
состоит в том, что она позволяет программе делать различие между различными 
клавишами, которые соответствуют одному и тому же символу (например, две 
клавиши "1"). Недостаток - то, что функция клавиатуры ВІОЗ доступна только для 
чтения клавиатуры. Она не может быть "переадресована" к другому источнику 
"стандартного ввода", как может функция 005 Ввод ЗЮІІМ. 

А.10.6.2.1306 ЕКЕѴ>СНАК 

ЕКЕѴ>СНАР транслирует событие клавиатуры в соответствующего члена набора 
символов, если такое соответствие существует для этого события. 

Возможно, что несколько различных событий клавиатуры могут соответствовать 
одному и тому же символу, и другие события клавиатуры могут не соответствовать 
никакому символу. 

А.10.6.2.1325 ЕМІТ? 

Неопределенная задержка - это состояние связанное с устройством, типа принтер 
недоступен, которое требует вмешательства оператора, перед тем как устройство 
примет новые данные. 

А.10.6.2.1905 М3 

Каждая система имеет часы, хотя их частоты различаются. Так как много программ 
нуждаются в интервалах времени, предлагается это слово. Использование 
миллисекунд как внутреннего элемента времени - это практичный "наименьший общий 
знаменатель" внешнего элемента. Принятое разработчиками, оно будет использовать 
"такты системных часов" (безотносительно их размера) как внутренний элемент и 
соответствующим образом преобразовывать. 

А.10.6.2.2292 ТІМЕ&ОАТЕ 

Большинство систем имеет часы/календарь реального времени. Это слово дает 
переносимый доступ к нему. 

А.11 Дополнительный набор слов доступа к файлам 

Много систем РогЬЬ поддерживает доступ к базовой файловой системе, и много из 
них поддерживает интерпретацию РогЬЬ из файлов исходного текста. РогЬЬ-83 
Стандарт не адресовал файлы базовой 03. Тем не менее, степень подобия 
существует среди современных реализаций. 

Например, файлы должны быть открыты и закрыты, созданы и удалены. Реализации 
файловой системы РогЬЬ отличаются главным образом в обработке и расположении 
кодов исключений, и в формате строк идентифицирующих файлы. Основной механизм 
для создания блоков управления файлом мог бы или не мог бы быть видимым. Мы 
хотели сохранить его невидимым. 

Файлы должны также читаться и писаться. Текстовые файлы, если поддерживается, 
должны читаться и писаться одной строкой за раз. Интерпретация текстовых файлов 
подразумевает, что они так или иначе интегрированы в механизм ввода текстового 
интерпретатора. Эти и другие требования оформлены в расширение набора слов 
доступа к файлу. 
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Большинство изученных существующих реализаций используют простые Английские 
слова для общих базовых файловых функций: ОРЕМ, ОБОЗЕ, РЕАЭ, и т.д. Хотя мы 
предпочли бы делать аналогично, было бы так много незначительных изменений в 
реализации этих слов, что принятие любого специфического значения сломала бы 
много существующего кода. Мы использовали названия с суффиксом -РІІ_Е для 
большинства этих слов. Мы поощряем разработчиков приспосабливать их однословные 
примитивы к АІ\І5 поведению, и надеемся что, если это сделано на широко 



распространенном основании мы можем принять лучшие имена определений в будущем 
стандарте. 

Специфические разъяснения для членов этого набора слов следуют далее. 

А.11.3 Дополнительные условия применения 
А.11.3.2 Блоки в файлах 

Много систем многократно используют идентификаторы файла; когда файл закрыт, 
впоследствии открытый файл может получить тот же самый идентификатор. Если 
первоначальный файл имеет блоки все еще в блочных буферах, они будут 
неправильно связаны с недавно открытым файлом с бедственным результатом. 
Система блочных буферов должна быть сброшена на диск, чтобы избежать этого. 

А.11.6 Словарь 


А.11.6.1.0765 ВІЦ 

Некоторые операционные системы требуют, чтобы файлы были открыты в различном 
режиме, чтобы обратиться к их содержанию как неструктурированному потоку 
двоичных данных скорее, чем как к последовательности строк. 

Параметры для РЕАО-РІІ_Е и Ѵ\/РІТЕ-РІІ_Е - массивы символьных запоминающих 
элементов, каждый элемент состоит, по крайней мере, из 8 бит. Технический 
Комитет подразумевает что, в режиме ВІІМ, содержание этих запоминающих элементов 
может быть записано в файл и позже прочитано назад без чередования. Технический 
Комитет отказался решать проблемы относительно воздействия "місіе" символов в 
Файловых и Блочных наборах слов. 

А.11.6.1.1Ѳ1Ѳ СРЕАТЕ-РШЕ 
Типичное использование: 

: X . . 5" ТЕ5Т.РТН" РА/ СРЕАТЕ-РШЕ АБОРТ" СРЕАТЕ-РШЕ РАШЕО" 


А.11.6.1.1717 ІІМСШШЕ-РШЕ 

Вот - две альтернативы реализации для сохранения спецификации входного 
источника при наличии ввода текстового файла: 

1) Сохранить позицию файла (как возвращено РІІ_Е-Р05ІТІ0І\І) начала 
интерпретируемой строки. Для восстановления спецификации входного источника, 
искать эту позицию и перечитать строку во входной буфер. 
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2) Распределить 
входного файла, 
шагов "искать и 
и другие каналы 


отдельный буфер строки для каждого активного текстового 
используя этот буфер как входной буфер. Этот метод избегает 
перечитывать", и позволяет использовать "псевдофайлы" типа ріре 
связи только-последовательного-доступа. 


А.11.6.1.1718 ІІМСШШЕО 
Типичное использование: 

... 5" Тііепате" ІМСШОЕО 


А.11.6.1.1970 ОРЕІМ-РШЕ 
Типичное использование: 

: X . . 5" ТЕ5Т.РТН" Р/Ѵ\/ ОРЕМ-РШЕ АБОРТ" ОРЕМ-РШЕ РАШЕО" . 
А.11.6.1.2080 РЕАО-РШЕ 

Типичный последовательный алгоритм обработки файла мог бы напоминать: 


ВЕСШ ( ) 

. . . РЕАБ-РШЕ ТНРОЫ ( длина ) 

201ІР МНШЕ ( длина ) 



РЕРЕАТ 


( ) 
( ) 


В этом примере ТИРОМ используется для обработки (неожиданных) исключительных 
ситуаций, которые сообщаются как ненулевые значения возвращаемого значения іог 
из РЕАР-РШЕ. Конец файла сообщается как нулевое значение "длины" возвращаемого 
значения. 


А.11.6.1.2Ѳ9Ѳ КЕАР-ІЛМЕ 

Реализациям разрешено сохранять ограничитель строки в буфере памяти, чтобы 
позволить использовать функции чтения строки, предоставленные базовыми 
операционными системами, некоторые из которых сохраняют ограничитель. Без этого 
условия, мог бы быть необходим временный буфер. Двух символьное ограничение 
достаточно для подавляющего большинства существующих операционных систем. 
Реализации на базовых операционных системах, чья последовательность 
ограничителей строки больше двух символов, могут иметь специальное действие для 
предотвращения запоминания больше двух символов ограничителей. 

Стандартные Программы не могут зависеть от присутствия никакой такой 
последовательности ограничителей в буфере. 

Типичный последовательный строчно-ориентированный алгоритм обработки файла мог 
бы напоминать: 

ВЕ6ІМ ( ) 

. . . ПЕАР-ІЛМЕ ТИРОМ ( длина поі-еоі-ііад ) 

МИШЕ ( длина ) 

... ( ) 

РЕРЕАТ РРОР ( ) 


193 


В этом примере ТИРОМ используется для обработки (неожиданной) исключительной 
ситуации 1/0, которая сообщается как ненулевое значение возвращаемого значения 
"іог" из КЕАР-ІЛМЕ. 

РЕАО-ІЛМЕ нуждается в отдельном флаге конца файла, потому что пустая (нулевая 
длина) строка - стандартное событие, таким образом строка нулевой длины не 
может использоваться для обозначения конца файла. 

А.11.6.1.2165 5" 

Типичное использование: 

... 5" ссс" . . . 

Семантика интерпретации для 5" предназначена для предоставления простого 
механизма ввода строки в состоянии интерпретации. Так как реализация может 
предоставлять только один буфер для интерпретируемых строк, интерпретируемая 
строка подвержена перезаписи следующим выполнением 5" в состоянии 
интерпретации. Подразумевается, что нет стандартного слова иного, чем 5" 
могущего быть причиной перезаписи интерпретируемой строки. Однако, так как 
слова типа ЕѴАШАТЕ, 1_0А0, ІІ\ІСІ_ІЮЕ-РІІ_Е и ІІМОШРЕР могут приводить к 
интерпретации произвольного текста, возможно включая экземпляры 5", 
интерпретируемая строка может быть сделана недействительной некоторыми 
использованиями этих слов. 

Когда может возникать возможность перезаписи строки, благоразумно копировать 
строку в "безопасный" буфер, распределенный приложением. 

Программам, желающим производить анализ способом 5" советуют использовать РАП5Е 
или МОКР СОІЛМТ вместо 5", предотвращая перезапись интерпретируемого строкового 
буфера. 


А.12 Дополнительный набор слов для плавающей точки 



Технический Комитет рассмотрел много предложений, имеющих дело с включением и 
составом Наборов Слов с Плавающей точкой в А№ Рогбб. Хотя это обсуждалось, что 
А№ Рогбб не должен адресовать арифметику с плавающей точкой, и многочисленные 
приложения Рогбб не нуждаются в плавающей точке, имеется растущее число важных 
приложений Рогбб от электронных таблиц до научных вычислений, которые требуют 
использования арифметики с плавающей точкой. Первоначально Технический Комитет 
принял предложения, которые составили РогбИ Ѵепсіогз бгоир Ріоабіпд-Роіпі; 
ЗбапсІагсІ, впервые изданный в 1984, основу для включения плавающей точки в А№ 
Рогбб. Есть значительная общая практика и опыт с Рогбб Ѵепсіогз бгоир Ріоабіпд- 
Роіпб ЗбапсІагсІ. Впоследствии технический Комитет принял предложения, которые 
помещали основную арифметику с плавающей точкой, стек и слова поддержки в 
наборе слов с плавающей точкой и трансцендентные функции с плавающей точкой в 
Расширении набора слов с плавающей точкой. Технический комитет также принял 
такие предложения: 

- изменены имена для ясности и последовательности; например, РЕАІ_5 на Р60АТ5, и 
РЕАІ_+ на Р1_0АТ+. 

- удалены слова; например, РРІСК. 

- добавлены слова для законченности и увеличенных функциональных возможностей; 
например, Р5ІІМС05, Р~, 0Р@, ОР!, 5Р§ и 5Р! . 

Несколько проблем относительно набора слов с плавающей точкой были разрешены 
консенсусом в Техническом Комитете: 
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Стек с плавающей точкой: По умолчанию стек с плавающей точкой отделен от стеков 
данных и возвратов; однако реализация может сохранять числа с плавающей точкой 
на стеке данных. Программа может определять, сохраняются ли числа с плавающей 
точкой на стеке данных передачей строки РІ_0АТІІ\ІС-5ТАСК в ЕІМѴІРОММЕІМТ? . Это опыт 
нескольких членов Технического Комитета, что с надлежащей практикой 
кодирования, возможно написать код с плавающей точкой, который будет работать 
тождественно на системах с отдельным стеком с плавающей точкой и с числами с 
плавающей точкой сохраняемыми на стеке данных. 

Ввод с плавающей точкой: Текущее основание должно быть ОЕСІМАб. Ввод с 
плавающей точкой - не разрешен в произвольном основании. Все числа с плавающей 
точкой, которые нужно интерпретировать АИЗ Рогбб Системой должны содержать 
индикатор экспоненты "Е" (см. 12.3.7 Преобразование входных чисел текстового 
интерпретатора). Консенсус в Техническом Комитете считал эту форму ввода 
плавающей точки в более общем использовании, чем альтернатива, которая имела бы 
режим ввода с плавающей точкой, который позволил бы числам с внедренными 
десятичными точками быть обработанными как числа с плавающей точкой. 

Представление с плавающей точкой: Хотя формат и точность мантиссы и формат и 
диапазон экспоненты числа с плавающей точкой - определенное реализацией в АИЗ 
Рогбб, Расширение набора слов с плавающей точкой содержит слова ЭР§, 5Р@, РР!, 
и 5Р! для выборки и сохранения в памяти чисел с двойной и с одинарной точностью 
формата ІЕЕЕ с плавающей точкой. Формат ІЕЕЕ с плавающей точкой обычно 
используется числовыми математическими сопроцессорами и для обмена данными с 
плавающей точкой между программами и системами. 

А.12.3 Дополнительные условия применения 

А.12.3.5 Выравнивание адреса 

В определении специализированных структур данных с плавающей точкой знайте, что 
СРЕАТЕ не обязательно оставляет указатель области данных, выровненный для 
различных типов данных с плавающей точкой. Программы могут выполнять требование 
для различных видов выравнивания с плавающей точкой, определяя соответствующее 
выравнивание во время компиляции и во время выполнения. 

Например: 



: РССШ5ТАІМТ ( Р: г -- ) 

СРЕАТЕ РАИСМ НЕВЕ 1 РІ.0АТ5 АЕЕОТ Р! 

00Е5> ( Р: -- г ) РАІЛбНЕЭ Р§ ; 

А.12.3.7 Преобразование входных чисел текстового интерпретатора 

Технический Комитет более чем однажды получал предложение, что текстовый 
интерпретатор в Стандартных системах Рогіііі должен обрабатывать числа, которые 
имеют внедренную десятичную точку, но не экспоненту, как числа с плавающей 
точкой скорее, чем числа две-ячейки. Это предложение, хотя это имеет 
достоинство, всегда проваливалось, потому что это будет ломать очень много 
существующего кода; много существующих реализаций помещают полную цифровую 
строку на стек как двойное число и используют другие средства для 
информирования приложения о местоположении десятичной точки. 

А.12.6 Словарь 
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А. 12.6.1.0558 >Р1_0АТ 

>Р1_0АТ дает возможность программам читать данные с плавающей точкой в четком 
А5СІІ формате. Оно принимает намного более широкий синтаксис, чем текстовый 
интерпретатор, так как последний определяет правила для создания исходных 
текстов программ, тогда как >Р1_0АТ определяет правила для приема данных. 

>Р1_0АТ определен так широко, как возможно разрешить ввод данных из А№ Рогіб 
Систем также как другие широко используемые стандартные среды программирования. 

Это синтез обычной практики РОВТРАІМ. Внедренные пробелы явно запрещаются в 
большинстве научных использований, как другие разделители полей типа запятой 
или наклонной черты вправо. 

В то время как >Р1_0АТ не требует обрабатывать строку пробелов как нуль, это 
поведение строго поощряется, так как будущая версия А№ РогііИ может включать 
такое требование. 

А.12.6.1.1427 Р. 

Например, 1ЕЗ Р. отображает 1000.. 

А. 12.6.1.1492 РСОИЗТАІМТ 
Типичное использование: 

г РСО№ТАІ\ІТ пате 

А.12.6.1.1552 РІ_ІТЕВАІ_ 

Типичное использование: 

: X ...[...( г ) ] РІ_ІТЕРАІ_ ... ; 

А.12.6.1.1630 РѴАРІАВ1_Е 
Типичное использование: 

РѴАРІАВІ_Е пате 

А.12.6.1.2143 РЕРРЕ5ЕІМТ 

Это слово предоставляет примитив для отображения чисел с плавающей точкой. 
Некоторые форматы с плавающей точкой, в том числе определенные ІЕЕЕ-754, 
позволяют представление чисел вне диапазона определенного реализацией. Они 
включают плюс и минус бесконечности, денормализованные числа, и другие. В этих 
случаях мы ожидаем, что ВЕРВЕ5ЕІМТ будет обычно реализовано способным возвращать 
соответствующе символьные строки, типа "+іпТіпі1;у" или "пап", возможно 
обрезанные. 

А.12.6.2.1489 РАТАИ2 

Р5ІІМС05 и РАТАИ2 - комплиментарная пара операторов, которые преобразовывают 
углы в 2-вектора и наоборот. Они обязательны для большинства геометрических и 



физических приложений, так как они правильно и однозначно обрабатывают это 
преобразование во всех случаях кроме нулевых векторов, даже когда тангенс угла 
был бы бесконечен. 


РЗІІМСОЗ возвращает Декартовый единичный вектор в направлении данного угла, 
измеренного против часовой стрелки от положительной оси X. Порядок результата 
на стеке, а именно у ниже х, разрешает 2-векторному типу данных дополнительно 
рассматриваться и использоваться как отношение аппроксимирующее тангенс угла. 
Таким образом, фраза РЗІІМСОЗ Р/ -функционально эквивалентна РТАМ, но полезна 
только для ограниченного и прерывистого диапазона углов, тогда как Р5ІМС05 и 
РАТАМ2 полезны для всех углов. 
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Это расположение было найдено удобным в течение почти двух десятилетий, и имеет 
дополнительную выгоду - простоту запоминания. Заключение из этого наблюдения - 
это что векторы вообще должны появляться на стеке в этом порядке. 

Порядок параметров для РАТАМ2 тот же самый, преобразовывает вектор в обычное 
представление скалярного угла. Таким образом, для всех углов Р5ІМС05 РАТАМ2 - 
это тождество в пределах точности арифметики и диапазона параметра Р5ІМС03. 
Заметьте что, в то время как Р5ІМС05 всегда возвращает допустимый вектор 
элемента, РАТАМ2 примет любой ненулевой вектор. Неопределенная ситуация 
существует, если векторный параметр для РАТАМ2 имеет нулевую величину. 

А.12.6.2.1516 РЕХРМ1 

Эта функция позволяет точное вычисление, когда его параметры - близки к нулю, и 
предоставляет полезное ядро для стандартных показательных функций. 
Гиперболические функции, такие как созіі(х), могут быть эффективно и точно 
реализованы использованием РЕХРМ1; точность теряется в этой функции для малых 
значений х, если используется слово РЕХР. 

Важное приложение этого слова в финансах; говорите, что ссуда возмещена в 15 % 
в год; какова суточная дача? На компьютере с единичной точностью (6 десятичных 
цифр) точность: 

1. Использование РІ_М и РЕХР: 

РІ_М от 1.15 = 0.139762, 
деление на 365 = 3.8291ѲЕ-4, 

формирование экспоненты, используя РЕХР = 1.00038, и 
вычитание единицы (1), и преобразование в проценты = 0.038%. 

Таким образом, мы имеем точность только две цифры. 

2. Использование РІ_МР1 и РЕХРМ1: 

РЫМР1 от 0.15 = 0.139762, (это - то же самое значение как в первом 
примере, хотя с параметром ближе к нулю оно не может быть таким) 

деление на 365 = 3.82910Е-4, 

формирование экспоненты, и вычитание единицы (1) , 
используя РЕХРМ1 = 3.82983Е-4, 
и преобразование в проценты = 0.0382983%. 

Это - точность полных 6 цифр. 

Присутствие этого слова позволяет гиперболическим функциям быть вычисленными с 
пригодной для использования точностью. Например, гиперболический синус может 
быть определен как: 

: Р5ІІМН ( П -- г2 ) 

РЕХРМ1 РОІІР РОІІР 1.0Е0 Р+ Р/ Р+ 2.0Е0 Р/ ; 



А. 12.6.2.1554 РІ.МР1 

Эта функция позволяет точную компиляцию, когда ее параметры близки к нулю, и 
предоставляет полезное ядро для стандартных логарифмических функций. Например, 
РБИ может быть реализована как: 
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: РІ_М 1.ѲЕѲ Р- РЦИР1 ; 

См.: А.12.6.2.1516 РЕХРМ1. 

А. 12.6.2.1616 РЗІІМСОЗ 
См.: А.12.6.2.1489 РАТАИ2. 

А.12.6.2.1640 Р~ 

Оно предоставляет три типа "равенства с плавающей точкой" в общем использовании 
-- "закрытое" в абсолютных терминах, точное равенство как представлено, и 
"относительно закрытое". 

А. 13 Дополнительный І_осаІ5 набор слов 

Технический Комитет имел проблему с Іосаіз. было убедительно аргументировано, 
что А№ РогІІі не должен ничего говорить о Іосаіз, так как: 

- нет, ясной принятой практики в этой области; 

- не все программисты РогІН используют их или даже знают то, чем они являются; 

- и немного реализаций используют один и тот же синтаксис, не говоря уже о тех 
же широких правилах использования и общих подходах. 

Также было аргументировано, это будет казаться одинаково убедительно, что 
нехватка каких либо стандартных подходов к Іосаіз - это точно причина для 
нехватки принятой практики, так как Іосаіз являются очень нетривиальными для 
реализации переносимым и практичным способом. Было далее аргументировано, что 
пользователи, которые выбрали стать зависящими от Іосаіз, имеют тенденцию быть 
связанными с единственным продавцом и имеют мало стимулов для присоединения к 
группе, которая, на это надежда, "широко примет" А№ РогИл, вместо Стандартного 
обращения к его проблемам. 

Так как Технический Комитет был не способен достигнуть твердого согласия 
относительно того игнорировать Іосаіз или при принять синтаксис какого либо 
специфического продавца, он искал некоторый путь решения проблемы, которую был 
не способен просто отклонить. Понимание, что никакой отдельный механизм или 
синтаксис не может одновременно удовлетворить желания, выраженные во всех 
предложениях Іосаіз, которые были получены, упростило постановку задачи, чтобы 
определить механизм Іосаіз, так: 

- является независимым от любого специфического синтаксиса; 

- является расширяемым пользователем; 

- допускает использование произвольных идентификаторов Іосаі в контексте 
отдельного определения; 

- поддерживает фундаментальные типы данных размера ячейки РогІІі; и 

- работает согласовано, особенно что касается реентерабельности и рекурсии. 

Техническому Комитету кажется, что так много тех, кто активно используют 
Іосаіз, затрудняются в работе с ними, и это в настоящее время согласие 
Технического Комитета что, если А№ РогІІі имеет, что ни будь сказать 
относительно предмета, то это приемлемая вещь для того, чтобы это говорить. 

Этот подход, определения (І_ОСАІ_), предложен как единственный, который может 
использоваться с небольшим количеством пользовательского кодирования для 
реализации некоторых, но не всех, схем Іосаіз в использовании. Следующие 
примеры кодирования иллюстрируют, как это может использоваться для реализации 



двух синтаксисов. 
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- Синтаксис, определенный этим Стандартом и используемый в системах 
СгеаЕіѵе ЗоІиЕіопз, Іпс.: 

: І_0САІ_5| ( "пате... пате |" -- ) 

ВЕС™ 

ВС МОРО СОЕІІЧТ ОѴЕР С@ 

[СНАР] | - ОѴЕР 1 - ОР \л/НІІ_Е 
(ЕОСАЕ) 

РЕРЕАТ 20Р0Р Ѳ Ѳ (ЕОСАЕ) 

; ІММЕОІАТЕ 

: ЕХАМРІ_Е ( п -- п**2 п**3 ) 

Е0САЕ51 N | N ОЕІР N * ОЕІР N * ; 

- Предложенный синтаксис: ( ЕОСАЕ пате ) с дополнительными правилами 
использования: 

: ЕОСАЕ ( "пате" -- ) ВЕ МОРО СОІЮТ (ЕОСАЕ) ; ІММЕОІАТЕ 

: ЕШ-Е0САЕ5 ( -- ) 0 0 (ЕОСАЕ) ; ІММЕОІАТЕ 

: ЕХАМРЕЕ ( п -- п п**2 п**3 ) 

ЕОСАЕ N ЕШ-Е0САЕ5 N ОЕІР N * ОЕІР N * ; 

Другие синтаксисы могут быть реализованы, хотя некоторые, вероятно, будут 
требовать значительно большие усилия или в некоторых случаях преобразование 
программы. Все же другие подходы Іосаіз полностью несовместимы из-за больших 
различий в правилах использования и в некоторых случаях даже контекста 
идентификаторов. Например, законченная схема Іосаі использованная Юбпз Норкіпз 
имела сложную семантику, которая не может быть повторена в терминах этой 
модели. 

Для подкрепления намерений раздела 13, вот два примера фактического 
использования Іосаіз. Первый иллюстрирует правильное использование: 

a) : { ( "пате ... }" - ) 

ВЕ0ІМ Вб МОРО СОЕІІМТ 

ОѴЕР С@ [СНАР] } - ОѴЕР 1 - ОР МНІбЕ 
(ЕОСАб) 

РЕРЕАТ 20Р0Р 0 0 (ЕОСАб) 

; ІММЕОІАТЕ 

b) : ЮЕ ( а Ь с -- п ) 

>Р 2* Р> 20ЕІР + Ѳ 

{ А№ 2В+С С 2В А } 

2 Ѳ 00 1 А№ + I + ТО А№ А№ . СР ЕООР 

А№ . 2В+С . С . 2В . А . СР А№ 


С) 100 300 10 ЮЕ 
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Слово { в а) определяет синтаксис объявления Іосаі, который окружает список 
Іосаіз фигурными скобками. Оно не делает чего ни будь фантастического, типа 
переупорядочивания Іосаіз или предоставления начальных значений для некоторых 
из них, так Іосаіз инициализируются со стека в заданном по умолчанию порядке. 
Определение ЮЕ в Ь) иллюстрирует использование этого синтаксиса. Заметьте, что 



работа выполнена во время выполнения в этом определении прежде, чем объявлены 
Іосаіз. Хорошо использовать стек возвратов, пока что-либо помещенное туда, 
удалится до начала объявления. 

Заметьте, что перед объявлением Іосаіз, удвоено В, вычислено подвыражение 
(2В+С), и предусмотрено начальное значение (нуль) для АІ\І5. После того, как 
Іосаіз были объявлены, ЮЕ продолжает использовать их. Заметьте, что к Іосаіз 
можно обращаться и модифицировать в пределах сіо-іоорз. Эффект интерпретации 
строки с) должен отобразить следующие значения: 

1 (А№ первый раз через цикл), 

3 (А№ второй раз), 

3 (АІ\І5), 610 (2В+С), 10 (С), 600 (2В), 100 (А), апсі 
3 (А№ оставлено на стеке ЮЕ) . 

Имена Іосаіз исчезают после того, как ЮЕ было откомпилировано. Память и 
значение Іосаіз появляются, когда объявлены Іосаіз ЮЕ и исчезают как ЮЕ 
возвращается к его вызывающей программе в ; (точка с запятой). 

Второй набор примеров иллюстрирует различные вещи, которые нарушают правила. Мы 
принимаем, что определения І_0САІ_ и ЕІ\Ш-І_0САІ_5 выше присутствуют наряду с { из 
предшествующего примера. 

сі) : 2ЕР0 0 Р05ТР0ІМЕ ІЛТЕКАІ. Р05ТР0МЕ ЦОСАЦ ; ІММЕОІАТЕ 
е) : МОЕ ( а Ь ) 

2ЕР0 ТЕМР І_0САІ_ В 1+ І_0САІ_ А+ 2ЕР0 АІЧ5МЕК ; 

1) : ВОВ (аЬссІ) {00} { В А } ; 

Вот - два определения с различными нарушениями правила 13.3.3.2а. В е) 
объявление из ТЕМР законно и создает Іосаі, чье начальное значение нулевое. Это 
- хорошо потому что выполняемый код, который генерирует 2ЕР0, предшествует 
первому использованию (І_0САІ_) в определении. Однако, 1+ предшествующее 
объявлению А+ незаконно. Аналогично использование 2ЕР0 для определения АІМ5МЕР 
незаконно, потому что оно генерирует выполняемый код между использованиями 
(І_0САІ_) . Наконец, МОЕ заканчивается незаконно (не ЕІ\Ю-І_0САІ_5) . ВОВ в Т) 
нарушает правило против объявления двух наборов Іосаіз. 

д) : АШ ( а Ь -- Ь ) ЭІІР >Р 01ІР ІР { В А } ТНЕМ Р> ; 

б) : ЭАІМЕ ( а Ь - - п ) { В А } А В + Ж АВ - К> / ; 

АШ в д) нарушает два правила. ІР ... ТНЕІМ вокруг объявления ее Іосаіз нарушает 
13.3.3.2Ь, и копия В, оставленная на стеке возвратов перед объявлением Іосаіз, 
нарушает 13.3.3.2с. ЭАІМЕ в б) нарушает 13.3.3.26, обращаясь к Іосаіз после 
размещения суммы А и В на стеке возвратов без первого удаления этой суммы. 

і) : СНКІ5 ( а Ь) 

{ В А } [ 1 ] А ЕХЕСІІТЕ 5 [ ' ] В >В00У ! [ ' А ] ІЛТЕКАІ. І_ЕЕ ; 
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СНКІ5 в і) иллюстрирует три нарушения 13.3.3.2е. Попытка ЕХЕСІІТЕ Іосаі 
вызванное А несовместимо с некоторыми реализациями. Запись в В через >В00У 
вероятно вызовет трагический результат во многих реализациях; кроме того, если 
Іосаіз находятся в регистрах, они не могут быть адресованы как память 
независимо оттого, что написано. 

Третье нарушение, в котором идентификатор исполнения для определения Іосаі 
передается как параметр к слову І_ЕЕ, если позволено, имел бы неприятное 
следствие, что І_ЕЕ может ЕХЕСІІТЕ лексему и получить значение для А от 
специфического выполнения СНРІ5 , которое вызывает на сей раз І_ЕЕ . 



13.3 Дополнительные условия применения 


Правило 13.3.3.2СІ может быть ослаблено без воздействия на целостность остальной 
части этой структуры. 13.3.3.2с не может. 

13.3.3.26 запрещает использование стека данных для хранения Іосаі, потому что 
нет четко определенных правил использования для пользователей программистов в 
таком случае. Конечно, если стек данных как-то используется таким способом, что 
нет никаких правил использования, при которых Іосаіз невидимы для программиста, 
логически являются не на стеке, и соответствует реализации. 

Минимальное требуемое число Іосаіз может (и должно) быть откорректировано, 
чтобы минимизировать стоимость соглашения для существующих пользователей 
Іосаіз . 

Обращение к предварительно объявленным переменным Іосаі, запрещено Разделом 
13.3.3.26 до того как любые данные, помещенные на стек возвратов приложением 
будут удалены, из-за возможного использования стека возвратов для хранения 
Іосаіз . 

Разрешение для Стандартной Программы управлять стеком возвратов (например, 
через >Р Р>) в то время как активны переменные Іосаі, чрезмерно сдерживает 
возможности реализации. Соглашение пользователей Іосаіз состояло в том, что 
І_оса1 средства представляют эффективную функциональную замену для манипуляции 
стеком возвратов, и было разумно ограничение стандартного использования только 
для одного метода. 

Обращение к Іосаіз в пределах, ОО..ЦООР явно разрешаются Разделом 13.3.3.2д, 
как дополнительное требование приспосабливания систем. Хотя слова, типа 
( І_0САІ_5 ), написаны системным Разработчиком, может требоваться сокровенное 
знание внутренней структуры стека возвратов, такое знание не требуется 
пользователю совместимых систем Рогіб. 

А.13.6 Словарь 

А.13.6.1.2295 ТО 
Типичное использование: 
х ТО пате 

См.: А.6.2.2295 ТО. 
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А. 13.6.2.1795 І_0САІ_5 | 

Возможная реализация этого слова и примера использования дана в А.13, выше. Это 
предназначено только как пример; приемлема любая реализация, соглашающаяся с 
описанной семантикой. 

А.14 дополнительный набор слов Распределения памяти 

Набор слов Распределения памяти предоставляет средства для запроса памяти 
отличной от непрерывной области данных распределенной АШОТ. Во многих средах 
операционных систем неуместно для процесса пред-распределять большие количества 
непрерывной памяти (как было бы необходимо для использования АШОТ). Набор слов 
Распределения памяти может запрашивать память из системы в любое время, без 
знания заранее адреса памяти, где она будет получена. 

А.15 Дополнительный набор слов утилит 

Эти слова были в широко распространенном общем использовании, начиная с самых 
ранних систем Рогіб. 



Хотя есть зависимости от окружений, присущие программам использующим ассемблер, 
фактически все системы Рогій предоставляют такую возможность. Поскольку так 
много программ Рогій предназначенных для приложений реального времени и 
внутренне непереносимых по этой причине, технический Комитет верит, что 
предоставление стандартного окна в ассемблеры - это полезное содействие 
программистам Рогій. 

Точно так же помощники программирования РІІМР, и т.д., являются ценными 
инструментальными средствами даже притом, что их специфические форматы будут 
колебаться в зависимости от реализаций Рогій и СРІІ. Эти слова - прежде всего, 
предназначены для использования программистом, и редко вызываются в программах. 

Одна из первоначальных целей Рогій состояла в том, чтобы стереть границу между 
"пользователем" и "программистом" - чтобы дать всю возможную мощь любому, кто 
имел случай использовать компьютер. Ничто из выше отмеченного или высказанного 
не должно быть истолковано, так что эта цель была оставлена. 

А.15.6 Словарь 


А.15.6.1.Ѳ22Ѳ .5 

.5 - удобство отладки, найденное почти на всех системах Рогій. Оно - повсюду 
упомянуто в текстах Рогій. 

А.15.6.1.2194 5ЕЕ 

5ЕЕ действует онлайновая форма документации слов, позволяя модификацию слов 
декомпиляцию и восстановление с соответствующими изменениями. 

А.15.6.1.2465 МОРОЗ 

МОРОЗ - удобство отладки, найденное почти на всех системах Рогій. Оно - повсюду 
упомянуто в текстах Рогій. 
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А.15.6.2.0470 ;СООЕ 

Типичное использование: 

: патех . . . <сгеа1е> . . . ;СООЕ . . . 

Где патех - определяющее слово, и <сгеа1е> - это СРЕАТЕ или любое определяемое 
пользователем слово, которое вызывает СРЕАТЕ. 

А.15.6.2.0930 СОРЕ 

Некоторые системы Рогій реализуют ассемблерную функцию, добавляя список слов 
А55ЕМВЦЕР к порядку поиска, используя текстовый интерпретатор для выделения 
постфиксного ассемблера с лексическими характеристиками, подобными исходному 
тексту Рогій. Как правило, в таких системах, ассемблирование заканчивается, 
когда интерпретируется слово ЕШ-СООЕ. 

А.15.6.2.1015 С5-РІСК 

Намерение состоит в том, чтобы повторить сіезі: на стеке потока управления так, 
чтобы оно могло быть разрешено больше чем однажды. Например: 

\ Условная передача управление на начало цикла 
\ Это подобно духу "С" инструкции "сопііпие". 

: 7ПЕРЕАТ ( сіезі -- сіезі ) \ Компиляция 
( Над -- ) \ Выполнение 

0 СЗ-РІСК Р05ТР0ІМЕ ІІМТІІ. 

; ІММЕОІАТЕ 

: XX ( -- ) \ Пример использования 7ПЕРЕАТ 
ВЕбІІЧ 

Над 7РЕРЕАТ ( Возврат к ВЕ6ІІМ если Над - 'Гаізе ) 



Лад 7РЕРЕАТ ( Возврат к ВЕ6ІМ если "Лад - Таізе ) 
Лад ІІМТІІ_ ( Возврат к ВЕ6ІМ если "Лад - Таізе ) 


А.15.6.2.1020 С5-Р0Ш 

Намерение состоит в том, чтобы изменить порядок, в котором огідз и сІезЕз на 
стеке потока управления должны быть разрешены последующими словами потока 
управления. Например, Ѵ\/НІІ_Е могло быть реализовано, в терминах ІР и С5-Р0Ш, 
следующим образом: 

: Ѵ\/НІІ_Е ( сІезЕ -- огід сІезЕ ) 

РОЗТРОИЕ ІР 1 С5-Р0Ш 
; ІММЕОІАТЕ 
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А.15.6.2.1580 Р0Р6ЕТ 
Типичное использование: 

... Р0Р6ЕТ пате ... 

РОРОЕТ предполагает, что вся информация необходимая для восстановления словаря 
к его предыдущему состоянию выводима как-нибудь из забываемого слова. В то 
время как это может быть верно в простой линейной модели словаря, это трудно 
реализовать в других системах РогЕб; например в системах с множественными 
адресными пространствами. Например, если РогЕб внедрен в РОМ, как Р0Р6ЕТ 
узнать, сколько РАМ восстановится, когда массив забыт? Общее и 
привилегированное решение предусмотрено МАРКЕР. 

А.15.6.2.2531 [ЕІ_5Е] 

Типичное использование: 

... Лад [ІР] ... [ЕІ_5Е] ... [ТНЕМ] ... 

А.15.6.2.2532 [ІР] 

Типичное использование: 

... Лад [ІР] ... [ЕІ_5Е] ... [ТНЕМ] ... 

А. 15.6.2.2533 [ТНЕІМ] 

Типичное использование: 

... Тіад [ІР] ... [ЕІ_5Е] ... [ТНЕМ] ... 

Программное обеспечение, которое выполняется на нескольких системных окружениях 

часто, содержит некоторый исходный текст, который зависит от окружения. 

Условная компиляция - это выборочное включение или исключение частей исходного 
текста во время компиляции - является одной методикой, которая часто 
используется для помощи в обслуживании такого исходного текста. 

Условная компиляция иногда делается с "разумными комментариями" - 
определениями, которые пропускают или не пропускают остаток строки, основываясь 
на некоторой проверке. Например: 

\ Если 16-ВіЕ? содержит ТРЕІЕ , строка с предшествующим 16ВІТ\ 

\ будет пропущена. Иначе, она не будет пропущена. 

ѴАРІАВЦЕ 16-ВІТ? 

: 16ВІТЧ ( -- ) 16-ВІТ? @ ІР Р03ТР0МЕ \ ТНЕМ 

; ІММЕОІАТЕ 

Эта методика работает на строке строчного базиса, и хороша для коротких 
изолированных разновидностей кодовых последовательностей. 



Более сложные проблемы условной компиляции предлагают метод вложенности, 
который может охватить больше одной исходной строки одновременно. Слова, 
включенные в АІ\І5 РогЦб расширение дополнительного набора слов утилит полезны 
для этой цели. Реализация, данная ниже, работает с любым входным источником 
(клавиатура, ЕѴАШІАТЕ, В1_0СК, или текстовый файл). 

2Ѳ4 


: [ЕЦЗЕ] ( -- ) 

1 ВЕ6ІМ 

ВЕ6ІІЧ ВЦ МОРО СОІІМТ ОІІР МНШЕ 
201ІР 5" [ІР]" СОМРАРЕ Ѳ= ІР 

20Р0Р 1+ 

ЕЦ5Е 

201ІР 5" [ЕЦ5Е]" СОМРАРЕ Ѳ= 

2БР0Р 1- ОІІР ІР 1+ ТНЕМ 
ЕЦ5Е 

5" [ТНЕІМ]" СОМРАРЕ Ѳ= ІР 
1- 
ТНЕІМ 
ТНЕМ 

ТНЕІМ 701ІР Ѳ= ІР ЕХІТ ТНЕІМ 
РЕРЕАТ 20Р0Р 
РЕРІШ 0= ІЛМТШ 
ОРОР 

; ІММЕОІАТЕ 

: [ІР] ( Пад -- ) 

Ѳ= ІР Р05ТР0ІМЕ [ЕЦ5Е] ТНЕМ 
; ІММЕОІАТЕ 

: [ТНЕІМ] ( -- ) ; ІММЕОІАТЕ 

А.16 Дополнительный набор слов порядка поиска 

Спецификация Порядка поиска и механизмы управления широко различаются. РІ6- 
РогТІі, РогШі-79, роІуРОРТН, и РогбІі-83 словарь и механизмы порядка поиска - все 
взаимно несовместимы. Законченный список несовместимых механизмов, используемых 
или предлагаемых, много длиннее. АЦ50/0ІМЦУ схема, описанная в РогШі-83 
Экспериментальных Предложениях, имеет прочную поддержку семейства. Однако 
многие полагают, что она была фундаментально порочна, и энергично против этого 
выступают. 

Признавая это разнообразие этот Стандарт определяет новый "примитивный" набор 
утилит, из которых могут быть созданы различные схемы. Этот примитивный набор 
слов порядка поиска предназначен, чтобы быть переносимым "набором конструкций" 
от которого могут быть сформированы слова порядка поиска скорее, чем интерфейс 
пользователя. АЦ50/0ІМЦУ или другие схемы "словаря", поддерживаемые главными 
продавцами РогЦН могут быть определены в терминах примитивного набора слов 
порядка поиска. 

Кодирование для идентификаторов списка слов місі могло бы быть маленьким-целым 
индексом в массиве записей определений списка слов, адрес области данных такой 
записи, смещение пользовательской области, идентификатор исполнения РогШі-83 
стиля непонятного словаря, адрес поля связи первого определения в списке слов, 
или что-нибудь еще. Это - полностью к системному разработчику. 

В некоторых системах интерпретация числовых литералов управляется включением 
"псевдо списка слов" которые распознают числа в конце порядка поиска. Эта 
методика обеспечивается поведением "порядка поиска по умолчанию" 5ЕТ-0Р0ЕР 
когда дан параметр -1. В системе, использующей традиционную реализацию 
АЦ50/0ІМЦѴ, минимальный порядок поиска был бы эквивалентен слову ОІМЦУ. 


\ 

Іеѵеі 



\ 

Іеѵеі 

асіг 

Іеп 

\ 

Іеѵеі 

асіг 

Іеп 

\ 

Іеѵеі' 



\ 

Іеѵеі 

асіг 

Іеп 

ІР \ 

Іеѵеі 

асіг 

Іеп 

\ 

Іеѵеі' 



\ 

Іеѵеі 

асіг 

Іеп 

\ 

Іеѵеі 



\ 

Іеѵеі' 



\ 

Іеѵеі' 



\ 

Іеѵеі 



\ 

Іеѵеі 
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Никогда не было переносимого способа восстановить сохраненный порядок поиска. 
Р83 (не Рогбб 83) представил слово РПЕѴІ01І5, которое почти сделало возможным 
"разгрузить" порядок поиска неоднократно выполняя фразу СОІМТЕХТ @ РПЕѴІ01І5. 
Порядок поиска мог быть "перезагруженным", повторением АІ_50 СОІМТЕХТ ! . К 
сожалению, не было никакого переносимого пути для определения, сколько списков 
слов были в порядке поиска. 

АІМ5 Рогбб удалил слово СОІМТЕХТ, потому что во многих системах его содержание 
относится к более чем одному списку слов, составляя проблемы переносимости. 

Заметьте, что : (двоеточие) больше не затрагивает порядок поиска. Предыдущее 
поведение, где список слов компиляции заменяет первый список слов порядка 
поиска, может быть эмулировано следующим переопределением : (двоеточие). 

: : СЕТ-ОПОЕП ЗѴУАР ОПОР СЕТ-СІІНПЕІМТ ЗѴУАР 5ЕТ-0П0ЕН : ; 

А.16.2 Дополнительные термины 

Порядок поиска 

Заметьте, что использование термина "список" не обязательно подразумевает 
реализацию как связанного списка. 

А.16.3.3 Поиск определений имен 

Другими словами не гарантируется, что следующее будет работать: 

: Р00 ...[... 5ЕТ-СІІННЕІМТ ] ... ПЕСІІП5Е . . . 

; ІММЕОІАТЕ 

ПЕСІІН5Е , ; (точка с запятой), и ІММЕОІАТЕ могут или не могут нуждаться в 
информации, сохраненной в списке слов компиляции. 

А.1'.' Словарь 

А.16.6.1.2192 5ЕАПСН-М0П0ІЛ5Т 

Строковый параметр для 5ЕАПСН-Ы0П0ІЛ5Т представленный с-асісіг и, скорее чем 
только с-асісіг как в РІІ\Ю. Комитет желает установить с-асісіг и как 
привилегированное представление строки на стеке, и приняло это представление 
для всех новых функций, которые принимают строковые параметры. В то время как 
это решение может вызывать реализацию 5ЕАПСН-М0П0ІЛ5Т несколько более трудную в 
существующих системах, комитет чувствует, что дополнительная трудность 
незначительна. 

Когда 5ЕАПСН-М0П01Л5Т не в состоянии найти слово, оно не возвращает строку, как 
делает РІІМО. Это - в соответствии с общим принципом, что слова Рогбб потребляют 
их параметры. 

А. 16.6.2.0715 АІ_50 

Вот - реализация АІ_50/0І\ІІ_Ѵ в терминах примитивного набора слов порядка поиска. 
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М0П0ІЛ5Т С0ІМ5ТАІМТ П00Т 

: 00-Ѵ0САВШ_АИѴ ( -- ) 
00Е5> § >П 

6ЕТ-0П0ЕК ЗѴУАР ОПОР 
П> ЗѴУАР 5ЕТ-0П0ЕП 


ПООТ 5ЕТ-СІІНПЕМТ 

\ Фактор реализации 
( ) ( П: иісіпеи ) 

( місіі . . . місіп-1 п ) 



0І5САР0 ( хі .. хи и - ) \ Фактор реализации 
0 ?Р0 РРОР 1_00Р \ РРОР и+1 элементов стека 


СРЕАТЕ РОРТН РОРТН -Іл/ОРОІЛЗТ , ОО-ѴОСАВШАРУ 

: ѴОСАВШАРУ ( пате -- ) М0Р01Л5Т СРЕАТЕ , 00-Ѵ0САВШ_АРѴ ; 

: АІ_50 ( -- ) 6ЕТ-0Р0ЕР ОѴЕР 5\л/АР 1+ 5ЕТ-0Р0ЕР ; 

: РРЕѴІ01І5 ( -- ) 6ЕТ-0Р0ЕР 5\л/АР ОРОР 1- 5ЕТ-0Р0ЕР ; 

: 0ЕРІІМІТІ0ІМ5 ( -- ) 6ЕТ-ОРРЕР ОѴЕР ЗЕТ-СІІРРЕМТ 0І5САР0 ; 

: ОІ\ІІ_Ѵ ( -- ) РООТ РООТ 2 5ЕТ-0Р0ЕР ; 

\ РогіН-83 версия; только удаляет ОІ\ІІ_Ѵ 
: 5ЕАІ_ ( -- ) 6ЕТ-0Р0ЕР 1- ЗЕТ-0Р0ЕР ОРОР ; 

\ Р83 апсі Р-РС версия; оставляет только СОІМТЕХТ 
: 5ЕАІ_ ( -- ) 6ЕТ-0Р0ЕР ОѴЕР 1 5ЕТ-0РРЕР 0І5САР0 ; 

Предшествующее определение ОІМІ_У в терминах "РООТ" списка слов следует 
использованию в Р83, и предполагает, что заданный по умолчанию порядок поиска 
только включает РООТ и РОРТН. Более переносимое определение РОРТН и ОІ\ІІ_Ѵ, без 
предположений: 

<опускает . . . М0Р0ІЛ5Т С0ІМ5ТАІМТ РООТ . . . строку> 

СРЕАТЕ РОРТН 6ЕТ-0РРЕР ОѴЕР , 0І5САР0 00-Ѵ0САВІІІ_АРѴ 
: ОШУ ( -- ) -1 5ЕТ-0Р0ЕР ; 

Вот - простая реализация 6ЕТ-0Р0ЕР и ЗЕТ-0Р0ЕР, включая соответствующее 
определение РІШ. Реализации М0Р0ІЛ5Т, 5ЕАРСН-М0Р0ІЛ5Т, 6ЕТ-СІІРРЕІМТ и 5ЕТ- 
СІІРРЕІМТ зависят от системных подробностей и не даны здесь. 

16 С0ІМ5ТАІМТ #Ѵ0С5 
ѴАРІАВБЕ #ОРРЕР 

СРЕАТЕ СОІМТЕХТ #Ѵ0С5 СЕШЗ АШОТ 

: 6ЕТ-0РРЕР ( -- місіі .. иісіп п ) 

#ОРОЕР § О 700 

#ОРОЕР @1-1- СЕШЗ СОІМТЕХТ + @ 

ЦООР 

#ОРРЕР @ 
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ЗЕТ-0Р0ЕР ( місіі .. місіп п — ) 

РІІР -1 = ІР 

ЦРОР <помещает системный список слов по умолчанию и п> 
ТНЕІМ 

ОЦР #ОРОЕР ! 

О ?РО I СЕШЗ СОІМТЕХТ + ! ЦООР 


РІШ ( с-асісіг -- с-асісіг 0 [ и 1 | м -1 ) 

О ( с-асісіг О ) 

#ОРОЕР @ 0 700 

ОѴЕР СОІІІМТ ( с-асісіг О с-асісіг 1 и ) 

I СЕШЗ СОІМТЕХТ + @ ( с-асісіг О с-асісіг 1 и місі) 

5ЕАРСН -М0Р0Ш5Т ( с-асісіг 0; 0 | м 1 | м -1 ) 

?ОЦР ІР ( с-асісіг 0; и 1 | м -1 ) 




25МАР 20Р0Р І_ЕАѴЕ ( И 1 | И -1 ) 

ТНЕМ ( с-асісіг 0 ) 

ЮОР ( с-асісіг Ѳ | и 1 | м -1 ) 


В реализации, где механизм поиска в словаре использует хеш-таблицу или кэш 
поиска для уменьшения времени поиска, 5ЕТ-0Р0ЕР мог бы быть должен восстановить 
хеш-таблицу или сбросить на диск кэш. 

А.17 Дополнительный строковый набор слов 

А.17.6 Словарь 


А.17.6.1.0245 /5ТРІМ6 

/5ТРІМ6 используется для удаления или добавления символов относительно "левого" 
конца символьной строки. Положительные значения п исключат символы со строки, в 
то время как отрицательные значения п будут включать символы слева от строки. 
/5ТРІМ6 - естественный агент МОКР и обычно доступный. 

А.17.6.1.0910 СМОѴЕ 

Если с-асІсІг2 находится в пределах исходной области, (то есть, когда с-асІсІг2 - 
не меньше чем с-асісігі и с-асІсІг2 - меньше чем количество с-асісігі и СНАР5 +), 
происходит размножение памяти. 

Типичное использование: 

Предположите символьную строку по адресу 100: "АВСО". 

Тогда после 


100 РІІР СНАР+ 3 СМОѴЕ строка по адресу 100 - "АААА". 

Объяснение для СМОѴЕ и СМОѴЕ> вытекает из МОѴЕ . 
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А.17.6.1.0920 СМОѴЕ> 

Если с-асісігі находится в пределах области назначения, (то есть, когда с-асісігі 
больше чем или равно с-асІсІг2 и с-асІсІг2 - меньше чем количество с-асісігі и СНАР5 
+), происходит размножение памяти. 

Типичное использование: 

Предположите символьную строку по адресу 100: "АВСО". 

Тогда после 


100 ОІІР СНАК+ 5Ѵ\/АР 3 СМОѴЕ>, строка по адресу 100 - "0000". 

А.17.6.1.0935 СОМРАРЕ 

Существующие системы РогбП исполняют строковые операции сравнения, использующие 
слова, которые отличаются проверкой правописания, параметрами ввода и вывода, и 
чувствительностью к регистру. Была выбрана одна широко используемая. 

А.17.6.1.2191 5ЕАРСН 

Существующие системы РогбИ исполняют операции поиска строки, использующие 
слова, которые отличаются проверкой правописания, параметрами ввода и вывода, и 
чувствительностью к регистру. Была выбрана одна широко используемая. 

А.17.6.1.2212 5І_ІТЕРАІ_ 

Текущие функциональные возможности 6.1.2165 5" могут быть предоставлены 
следующим определением: 

: 5" ( "ссс<цію1:е>" -- ) 

[СНАР] " РАК5Е Р03ТР0МЕ ЗИТЕРАБ 



; ІММЕОІАТЕ 
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С. Перспектива (информационное приложение) 

Цель этого раздела состоит в том, чтобы предоставить краткий неформальный обзор 
Рогііі как языка, иллюстрируя его хронологию, наиболее видные возможности, 
использование, и общие методы реализаций. Ничто в этом разделе не должно 
рассматриваться как обязывающее разработчиков или пользователей. Список книг и 
статей - данный в Приложении В для заинтересованных в больших познаниях о 
Рогііі . 

С. 1 Возможности Рогііі 

Рогііі предоставляет интерактивную среду программирования. Его первичные 
использования были - научные и индустриальные приложения типа оснащения 
аппаратурой, робототехника, управление процессом, графика и обработка 
изображений, искусственный интеллект и деловые приложения. Основные 
преимущества Рогііі включают быструю, интерактивную программную разработку и 
эффективное использование компьютерных аппаратных средств. 




О Рогіій часто говорят как языке, потому что это его наиболее видимый аспект. Но 
фактически, Рогій это и больше и меньше чем обычный язык программирования: 
больше в том, что все свойства, обычно связываемые с большим портфелем 
отдельных программ (компиляторы, редакторы, и т.д.) включены в пределах его 
диапазона, и меньше, в чем он испытывает недостаток (преднамеренно), сложная 
характеристика синтаксиса большинства языков высокого уровня. 

Первоначальные реализации Рогій были автономными системами, которые включали 
функции, обычно выполняемые отдельными операционными системами, редакторы, 
компиляторы, ассемблеры, отладчики и другие утилиты. Единственный простой, 
непротиворечивый набор правил управлял этим полным диапазоном свойств. Сегодня, 
хотя очень быстрые автономные версии все еще продаются для многих процессоров, 
есть также много версий, которые работают одновременно с обычными операционными 
системами типа М5 РОЗ и ІІІМІХ. 

Рогіій не получен из какого либо другого языка. В результате, его вид и 
внутренние характеристики могут казаться незнакомыми новым пользователям. Но 
простота Рогіій, высочайшая модульность, и интерактивная природа смещали 
начальную странность, делая его легким в изучении и в использовании. Новый 
программист Рогіій должен вложить некоторое время, осваивая его большой 
командный набор. После приблизительно месяца полных рабочих дней использования 
Рогіій, программист мог помнить большее количество его внутренней работы, чем 
возможно с обычными операционными системами и компиляторами. 

Наиболее нетрадиционная функция Рогіій - его расширяемость. Процесс 
программирования в Рогіій состоит из определения новых "слов" - фактически новых 
команд на языке. Они могут быть определены в терминах предварительно 
определенных слов, так как почти каждый обучает детей понятиям, объясняя их в 
терминах предварительно усвоенных понятий. Такие слова названы 
"высокоуровневыми определениями". Альтернативно, новые слова могут также быть 
определены в ассемблерном коде, поскольку большинство реализаций Рогіій включает 
ассемблер для базового процессора. 

Эта расширяемость облегчает разработку языков специального применения для 
специфических прикладных областей или дисциплин. 

Расширяемость Рогіій выходит за пределы только добавления новых команд к языку. 

С эквивалентной непринужденностью, можно также добавлять новые виды слов. То 
есть можно создать слово, которое непосредственно определит слова. Создавая 
такое определяющее слово, программист может определить специализированное 
поведение для слов, которые оно создаст, и которые будут эффективны во время 
компиляции, во время выполнения, или в обоих случаях. 
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Эта возможность позволяет определять специализированные типы данных, с полным 
контролем над структурой и поведением. Поскольку поведение времени-выполнения 
таких слов может быть определено высокоуровневым или в коде, слова созданные 
этим новым определяющим словом эквивалентны в работе всем другим видам слов 
Рогіій. Кроме того, также просто добавить новые директивы компилятора для 
реализации специальных видов циклов или других управляющих структур. 

Большинство профессиональных реализаций Рогій написано в Рогіій. Много систем 
Рогіій включают "транслятор метаязыка", который позволяет пользователю изменять 
непосредственно внутреннюю структуру системы Рогій. 

С.2 Хронология Рогіій 

Рогіій был изобретен Сйагіез Н. Мооге. Непосредственный результат работы Мооге в 
1960-е, первая программа, которая названа Рогіій была написана около 1970. 

Первая законченная реализация использовалась в 1971 в Маііопаі Расііо Азігопоту 
Ойзегѵаіогу на 11-метровом радио телескопе в Аризоне. Эта система была 
ответственна за наведение и слежение телескопа, сбор данных и запись их на 



магнитной ленте, и поддержку интерактивного графического терминала, на котором 
астроном мог анализировать предварительно зарегистрированные данные. 
Многозадачная природа системы позволила всем этим функциям быть выполненными 
одновременно, без разрешения конфликтов или другого вмешательства - очень 
продвинутая концепция для того времени. 

Система была настолько полезна, что астрономы со всех континентов начали 
просить о копиях. Его использование быстро распространилось, и в 1976 Рогбй был 
принят как стандартный язык Іпбегпаііопаі Азігопошісаі ІІпіоп. 

В 1973, Мооге и коллеги сформировали Рогіій, Іпс для изучения коммерческого 
использования языка. Рогбй, Іпс разработала многопользовательские версии Рогбй 
на миникомпьютерах для разнообразных проектов, в пределах от баз данных до 
научных приложений типа обработки изображений. В 1977, Рогіій, Іпс разработала 
версию для недавно представленных 8-бит микропроцессоров названную 
"шісгоРОРТН", которая успешно использовалась во встроенных в микропроцессор 
приложениях в Соединенных Штатах, Англии и Японии. 

Стимулированная объемом сбыта тісгоРОРТН, группа людей с компьютерным хобби в 
Северной Калифорнии заинтересовалась Рогбй, и в 1978 сформировала Рогбй 
Іпіегезі: Сгоир (РІ6). Они разработали упрощенную модель, которую они 
реализовали на нескольких микропроцессорах и издали распечатки и диски очень 
низкой стоимости. Интерес к Рогбй распространился быстро, и сегодня есть 
отделения Рогбй Іпбегезі; Сгоир по всей США и в более чем пятнадцати странах. 

К 1980, множество новых продавцов Рогбй пришло на рынок с версиями РогІй 
основанными на модели РІС. Прежде всего, предназначенные для персональных 
компьютеров, эти относительно недорогие системы Рогбй были распространены очень 
широко. 

С.3 Аппаратные реализации РогІй 

Внутренняя архитектура РогІй моделирует компьютер с двумя стеками, набором 
регистров, и другими стандартизированными возможностями. В результате, это было 
почти неизбежно, что кто-то пытался бы построить аппаратное представление 
фактического компьютера РогІй. 
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В начале 1980-ых, Роскмеіі произвела 6502-вариант с примитивами РогІй во 
встроенной РОМ, Роскиеіі 65Р11. Этот чип использовался успешно во многих 
внедренных микропроцессорных приложениях. В середине 198Ѳх 2і1од разработала 
28800 (5ирег8) которая предложила ЕІМТЕР (лез!), ЕХІТ (иппезі:) и МЕХТ в 
микропрограмме. 

В 1981, Мооге взялся проектировать реализацию на уровне кристалла виртуальной 
РогІй машины. Работая сначала в РогІй, Іпс и впоследствии с компанией запуска 
ІМОѴІХ, сформированной для разработки чипа, Мооге завершил конструкцию в 1984, и 
первые прототипы были произведены в начале 1985. Более ранние Рогбй процессоры 
были разработаны Наггіз Зешісопсіисііог Согр., Эойпз Норкіпз ІІпіѵегзіІу, и 
другими. 

С. 4 Попытки стандартизации 

Первым главным усилием по стандартизации РогІй была встреча в Утрехте в 1977. 
Посетители произвели предварительный стандарт, и согласились встретиться на 
следующий год. 1978 встречу также посетили члены недавно сформированной РогІй 
Іпіегезі; Сгоир. В 1979 и 1980 ряд встреч, посещаемых и пользователями и 
продавцами, произвели более всесторонний стандарт названный Рогій 79. 

Хотя Рогій 79 был очень влиятелен, много пользователей Рогій и продавцов нашли 
в нем серьезные недостатки, и в 1983 был выпущен новый стандарт названный Рогій 
83. 



Поощренная широко распространенным принятием Рогбб 83, группа пользователей и 
продавцов встретилась в 1986, чтобы исследовать выполнимость Атегісап Мабіопаі 
ЗбапсІагсІ. ХЗЛ4 Технический комитет по А№ Рогбб проводил ее первую встречу в 
1987. Этот Стандарт - это результат. 

С.5 Программирование в РогІИ 

Рогбб - подобный английскому язык, чьи элементы (называемые "слова") - это 
именованные элементы данных, процедуры, и определяющие слова, способные 
создавать элементы данных с настраиваемыми характеристиками. Процедуры и 
определяющие слова могут быть определены в терминах предварительно определенных 
слов или в машинном коде, используя встроенный ассемблер. 

РогІИ "слова" функционально аналогичны подпрограммам на других языках. Они - 
также эквивалентны командам на других языках - Рогбб размывает различия между 
лингвистическими элементами и функциональными элементами. 

Слова посылаются по имени или с клавиатуры или из источника программы. В 
результате, термин "слово" применяется и к программному (и лингвистическому) 
элементу и к их текстовым именам. В синтаксическом анализе текста Рогбб 
полагает, что слово будет любой строкой символов, ограниченных пробелами. Есть 
несколько специальных символов, которые не могут быть включены в слово или 
начало слова: пробел (универсальный разделитель), СР (который заканчивает ввод 
с терминала), и возврат или 0Е1_ (для возврата в течение ввода с клавиатуры). 
Много групп принимают соглашения об именах, чтобы улучшить удобочитаемость. 
Слова, встречающиеся в тексте, относятся к трем категориям: определенные слова 
(то есть, процедуры Рогбб), числа, и неопределенные слова. Например, вот - 
четыре слова: 

НЕПЕ 00Е5> ! 8493 
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Первые три - стандартно-определенные слова. Это означает, что они имеют входы в 
Рогбб словарь, описанный ниже, объясняя, что РогбИ должен делать, когда эти 
слова встретятся. Число "8493" возможно не будет найдено в словаре, и РогІИ 
преобразует его в двоичный код и поместит его в его магазинный стек для 
параметров. Когда Рогбб сталкивается с неопределенным словом и не может 
преобразовывать его к числу, слово возвращается пользователю с сообщением 
исключения. 

Архитектурно, слова Рогбб строго придерживаются принципов "структурного 
программирования": 

- Слова должны быть определены прежде их использования. 

- Логический поток ограничен последовательными, условными, и итерационными 
конструкциями. Включены слова для реализации наиболее полезных управляющих 
структур программы. 

- Программист работает со многими маленькими, независимыми модулями (словами) 
для максимальной контролируемости и надежности. 

Рогбб характеризуется пятью главными элементами: словарь, два магазинных стека, 
интерпретаторы, ассемблер, и виртуальная память. Хотя каждый из них может быть 
найден в других системах, комбинация производит совместные усилия, которые 
создают мощную и гибкую систему. 

С.5.1 словарь Рогбб 

Программа Рогбб организована в словарь, который занимает большую часть памяти, 
используемой системой. Этот словарь - связанный список элементов переменной 
длины, каждый из которых определяет слово. Содержание каждого определения 
зависит от типа слова (элемент данных, константа, последовательность операций, 



и т.д.). Словарь расширяем, обычно растет в область верхней памяти. На 
некоторых многопользовательских системах индивидуальные пользователи имеют 
частные словари, каждый из которых связан с общедоступным системным словарем. 

Слова добавляются в словарь "определяющими словами", более употребительное из 
которых - это : (двоеточие). Когда : выполняется, оно создает определение для 
слова, которое следует за ним. В классических реализациях содержимое этого 
определения - строка адресов предварительно определенных слов, которые будут 
выполнены по очереди всякий раз, когда вызывается определяемое слово. 
Определение заканчивается ; (точка с запятой). Например, вот - определение: 

: РЕСЕІѴЕ ( -- асісіг п ) РАО ОІІР 32 АССЕРТ ; 

Имя нового слова - РЕСЕІѴЕ. Комментарий (в круглых скобках) указывает, что оно 
не требует никаких параметров и возвратит адрес и счетчик на стеке данных. 

Когда РЕСЕІѴЕ выполняется, оно последовательно исполнит слова в остатке 
определения. Слово РАО помещает на стек адрес временной памяти используемой для 
обработки строки. ОІІР дублирует верхний элемент стека, так что мы теперь имеем 
две копии адреса. Число 32 также помещается на стек. Слово АССЕРТ берет адрес 
(предоставленный РАО) и длину (32) на стеке, принимает с клавиатуры строку до 
32 символов, которые будут помещены по определенному адресу, и возвращает число 
полученных символов. Копия адреса временной памяти остается на стеке ниже 
счетчика так чтобы подпрограмма, которая вызвала РЕСЕІѴЕ, могла использовать 
его, чтобы подобрать полученную строку. 
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С.5.2 Магазинные стеки 

Пример выше иллюстрирует использование магазинных стеков для передачи 
параметров между словами РогІИ. Рогбб поддерживает два магазинных стека, или 
списков І_ІРО. Они предоставляют связь между словами Рогбб плюс эффективный 
механизм для управления логическим потоком. Стек содержит 16-бит элементы на 8- 
бит и 16-бит компьютерах, и 32-бит элементы на 32-бит процессорах. Числа две- 
ячейки занимают две позиции стека, с самой старшей частью на вершине. Элементы 
на стеке могут быть адреса или элементы данных различных видов. Стеки имеют 
неопределенный размер, и обычно растут к меньшим адресам памяти. 

Хотя структура обоих стеков одинаковая, они имеют очень различное 
использование. Пользователь взаимодействует наиболее непосредственно со Стеком 
Данных, который содержит параметры, передаваемые между словами. Эта функция 
заменяет вызывающие последовательности, используемые обычными языками. Это 
внутренне эффективно, и делает подпрограммы в действительности 
реентерабельными. Второй стек назван Стеком Возвратов, поскольку его основная 
функция это держать адреса возврата для вложенных определений, хотя иногда там 
временно сохраняются другие виды данных. 

Использование Стека Данных (часто называемого просто "стек") ведет к нотации, в 
которой операнды предшествуют операторам. Слово АССЕРТ в примере выше брало 
адрес и счетчик со стека и оставляло там другой адрес. Точно так же слово по 
имени ВІ_АІ\ІК ожидает адрес и счетчик, и поместит определенное число пробелов 
( 2ѲН ) в области, начинающейся с этого адреса. Таким образом, 

РАО 25 ВІ_АІ\ІК 

заполнит рабочую область, чей адрес помещен на стек словом РАО, 25 пробелами. 
Прикладные слова обычно определяются, чтобы работать подобным образом. 

Например, 

1Ѳ0 ЗАМРЦЕЗ 


могло быть определено, чтобы делать запись 1ѲѲ измерений в массиве данных. 



Арифметические операторы также ожидают значения и оставляют результат на стеке. 
Например, + складывает два верхних числа со стека, заменяя их оба их суммой. 

Так как результаты операций оставляются на стеке, операции могут быть связаны 
вместе без необходимости определения переменных для использования как 
временной памяти. 

С.5.3 Интерпретаторы 

РогИп - традиционно интерпретирующая система, так как выполнение программы 
управляется скорее элементами данных, чем машинным кодом. Интерпретаторы могут 
быть медленны, но Рогіб поддерживает высокую скорость, требуемую для приложений 
реального времени при наличии двух уровней интерпретации. 

Первый - текстовый интерпретатор, который выделяет строки с терминала или 
запоминающего устройства и ищет каждое слово в словаре. Когда слово найдено, 
оно выполняется вызовом второго уровня, адресного интерпретатора. 

Второй - это "адресный интерпретатор". Хотя не все системы Рогіб реализованы 
таким образом, это была первая и - все еще основная технология реализации. В 
виду маленьких затрат на выполнение, адресный интерпретатор может выдавать 
очень компактную объектную программу, что было главным фактором в широком 
принятии Рогіб во внедренных системах и других приложениях, где желателен 
маленький объектный размер. 
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Адресный интерпретатор обрабатывает строки адресов или лексем, 
откомпилированных в определениях созданных : (двоеточие), выполняя определение 
указанное каждым. Содержание большинства определений - это последовательность 
адресов предварительно определенных слов, которые будут выполнены адресным 
интерпретатором в свою очередь. Таким образом, когда слово РЕСЕІѴЕ 
(определенное выше) выполняется, слово РАО, слово РІІР, литерал 32, и слово 
АССЕРТ будут последовательно выполнены. Процесс заканчивается точкой с запятой. 
Это выполнение не требует исследования словаря, синтаксического анализа, или 
другой логики, потому что, когда ПЕСЕІѴЕ было откомпилировано, словарь 
просматривался для каждого слова, и его адрес (или другая лексема) были 
помещены в следующую последовательную ячейку входа. Текст не был сохранен в 
памяти, ни даже в сжатой форме. 

Адресный интерпретатор имеет два важных свойства. Первое, это быстро. Хотя 
фактическая скорость зависит от специфической реализации, профессиональные 
реализации высоко оптимизированы, часто требуя только одну или две машинных 
команды на адрес. На большинстве эталонных тестов, хорошая реализация Рогіііі 
существенно превосходит по быстродействию интерпретирующие языки типа ВА5ІС или 
І_І5Р, и сравнивается благоприятно с другими компилирующими языками высокого 
уровня. 

Второе, адресный интерпретатор делает определения РогИп чрезвычайно 
компактными, так как каждая ссылка требует только одной ячейки. В сравнении, 
вызов подпрограммы, созданной большинством компиляторов, включает команды для 
обработки вызывающей последовательности (ненужной в РогІИ из-за стека) перед и 
после команды САШ или ЭЗР и адреса. 

Большинство слов в словаре РогІИ будет определено : (двоеточие) и 
интерпретировано адресным интерпретатором. Большинство РогИп сами определены 
таким образом. 

С.5.4 Ассемблер 

Большинство реализаций РогИп включают макроассемблер для СРІІ, на котором они 
работают. Используя определяющее слово ССЮЕ, программист может создавать 
определение, чье поведение будет состоять из выполнения фактических машинных 
команд. Определения СОРЕ могут использоваться для выполнения ввода-вывода, 



реализации арифметических примитивов, и выполнения другой машинно-зависимой или 
критической по времени обработки. При использовании СОРЕ программист имеет 
полный контроль над СРІІ, как с любым другим ассемблером, и определения СОРЕ, 
выполняются с полной машинной скоростью. 

Это - важное свойство Рогій. Оно разрешает явный машинно-зависимый код в 
управляемых частях со специфическими соглашениями связи, которые являются 
машинно-независимыми. Для перемещения приложения на другой процессор требуется 
перекодирование только СОРЕ слов, которые взаимодействуют с другими словами 
Рогіій точно одним и тем же способом. 

Ассемблеры Рогій настолько компактны (типично несколько Килобайт) что они могут 
быть резидентными в системе (как - компилятор, редактор, и другие утилиты). Это 
означает, что программист может вводить короткие определения СОРЕ и выполнять 
их немедленно. Это возможность особенно ценна в испытании заказных аппаратных 
средств. 

С.5.5 Виртуальная память 

Заключительный уникальный элемент Рогій - это его способ использования диска 
или другого запоминающего устройства как разновидности "виртуальной памяти" для 
данных и источника программы. Как в случае адресного интерпретатора, этот 
подход - историческая характеристика Рогіій, но ни в коем случае не универсален. 
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Диск разделен на 1024-байтовые блоки. В памяти предусмотрено два или более 
буфера, в которые блоки читаются автоматически, когда упоминаются. Каждый блок 
имеет установленный номер блока, который в чистых системах является прямой 
функцией его физического местоположения. Если блок в памяти изменен, он будет 
автоматически перезаписан, когда ее буфер должен будет повторно использован. 
Явное чтение и запись не необходимы; программа найдет данные в памяти всякий 
раз, когда она обращается к ним. 

Блочно-ориентированная обработка диска эффективна и проста в реализации для 
чистой системы Рогіій. В результате, блоки предоставляют полностью мобильный 
механизм для обработки источника программы и данных как чистых, так и версий 
Рогіій одновременно находящихся в памяти с различными базовыми операционными 
системами. 

Определения в блоках источника программы компилируются в память словом 1_0А0. 
Большинство реализаций включают редактор, который форматирует блок для 
отображения в 16 строк по 64 символа в каждой, и предусматривают команды, 
изменяющие источник. Пример источника Рогіій блока - дан на рис. С.1 ниже. 

Исходные блоки исторически были важным элементом в стиле Рогіій. Так же, как 
Рогіій определения могут рассматриваться лингвистическим эквивалентом 
предложений на естественных языках, блок аналогичен параграфу. Блок обычно 
содержит определения, связанные с общей темой, типа "векторная арифметика". 
Комментарий в верхней строке блока идентифицирует эту тему. Приложение может 
выборочно загружать требующиеся блоки. 

Блоки также используются для сохранения данных. Маленькие записи могут быть 
объединены в блок, или большие записи распространяться на несколько блоков. 
Программист может распределять блоки любым способом, удовлетворяющим 
приложение, и на чистых системах может увеличивать производительность, 
организуя данные для минимизирования движения головок диска. Несколько 
продавцов Рогіій разработали сложный файл и системы баз данных, основанные на 
блоках Рогій. 

Версии Рогіій, которые выполняются одновременно с 05 находящейся в памяти 
главного компьютера, часто реализуют блоки в файлах 05 главного компьютера. 
Другие используют базовые файлы исключительно. Стандарт требует, что бы блоки 



были доступны на системах, предоставляющих любые методы дискового доступа, 
поскольку они - единственные средства ссылка на диск, который может быть 
перемещаемым между чистой и одновременно находящейся в памяти с 05 
реализациями. 

С.5.6 Среда программирования 

Хотя этот Стандарт не требует, чтобы большинство систем Рогбй включало 
резидентный редактор. Он дает возможность программисту редактировать источник и 
перетранслировать его в выполнимую форму без покидания среды Рогій. Поскольку 
просто организовать приложение по уровням, часто возможно перетранслировать 
только самый верхний уровень (который обычно является в настоящее время 
разрабатываемым), процесс который редко занимает больше чем несколько секунд. 

Большинство систем Рогбй также предоставляют резидентные интерактивные средства 
отладки, включающие не только слова типа тех, что в 15. Дополнительный набор 
слов Утилит, но также и наличие способности исследовать и изменять содержание 
ѴАРІАВБЕ и других элементов данных и выполнять с клавиатуры большинство 
составляющих слов основной системы Рогбй и разрабатываемого приложения. 
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Комбинация резидентного редактора, интегрированных средств отладки, и 
непосредственной выполняемости большинства определенных слов ведет к очень 
интерактивному стилю программирования, который демонстрирует сокращение времени 
разработки. 

С.5.7 Расширенные возможности программирования 

Одна из необычных характеристик Рогбй - в том, что слова определяемые 
программистом при построении приложения становятся неотъемлемыми элементами 
самого языка, добавляя более и более мощные проблемно-ориентированные 
возможности. 

Например, Рогбй включает слова ѴАПІАВ1_Е и 2ѴАРІАВІ_Е для имени местоположения, в 
котором могут быть сохранены данные, также как С0№ТАІ\ІТ и 2С0№ТАІ\ІТ для имени 
значения одной и две-ячейки. Предположим, программист находит, что приложение 
нуждается в массивах, которые были бы автоматически индексированы по количеству 
элементов с двумя ячейками. Такой массив мог бы быть назван 2АРРАѴ. Префикс "2" 
в имени указывает, что каждый элемент в этом массиве займет две ячейки (как 
было бы содержание 2ѴАРІАВБЕ или 2С0№ТАІ\ІТ) . Префикс "2", однако, имеет 
значение только для человека и не более существенен для текстового 
интерпретатора, чем любой другой символ, который может использоваться для 
определения имени. 

Такое определение имеет две части, как есть два "поведения", связанные с этим 
новым словом 2АРПАѴ, одно во время компиляции, и одно в работе или времени 
выполнения. Они лучшие понятны, если мы посмотрим, как 2АКПАѴ используется для 
определения его массивов, и затем как массив мог бы использоваться в 
приложении. Фактически, это как можно было бы проектировать и реализовать это 
слово. 

В начале нисходящего процесса проектирования, вот как мы хотели бы использовать 
2АРРАѴ : 


10Ѳ 2АКРАѴ РА\л/ 50 2АКРАѴ РЕРІМЕО 

В первом случае, мы определяем массив 100 элементов длиной, чье имя - ПАМ. Во 
втором, массив - 50 элементов длиной, и именем РЕРІМЕО. В каждом случае 
параметр размера поставляется для 2АПРАѴ на стеке данных (интерпретатор текста 
Рогбй автоматически помещает числа там, когда он сталкивается с ними), и имя 
слова следует непосредственно. Этот порядок типичен для определяющих слов 
Рогбй. 



Когда мы используем КАМ или РЕРІМЕЭ, мы хотели бы поставлять на стеке индекс 
желаемого элемента, и возвратить на стеке адрес этого элемента. Такая ссылка 
типично имела бы место в цикле. Вот - типичный цикл, который принимает значение 
две-ячейки от гипотетического прикладного слова РАТА и запоминает его в 
следующем элементе РАМ: 

: АС(21ІІВЕ 100 0 00 ОАТА I РАМ 2! Ц00Р ; 

Имя этого определения - АСЦШРЕ. Цикл начинается с 00, заканчивается 1_00Р, и 
будет выполняться с индексными значениями, изменяющимися от 0 до 99. В пределах 
цикла, ОАТА получает значение. Слово I возвращает текущее значение индекса 
цикла, которое является параметром для РАМ. Адрес выбранного элемента, 
возвращенного РАМ, и значение, которое осталось на стек от ОАТА, передаются 
слову 2! (произносимое "бмо-зііоге" ), которое сохраняет два элемента стека по 
адресу. 
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Теперь, когда мы точно определили, что делает 2АРРАУ, и как ведут себя слова, 
которые оно определяет, мы готовы записать две части его определения: 

: 2АРРАУ ( п -- ) 

СРЕАТЕ 2* СЕІ_І_5 АШОТ 

00Е5> ( і а -- а') 5МАР 2* СЕШ5 + ; 

Часть определения перед словом 00Е5>, определяет поведение "во время 
компиляции", то есть что будет делать 2АРРАУ, когда оно нами используется для 
определения слова типа РАМ. Комментарий указывает, что эта часть ожидает число 
на стеке, которое является параметром размера. Слово СРЕАТЕ создает определение 
для нового слова. Фраза 2* СЕІ_І_5 преобразовывает параметр размера из элементов 
с двумя ячейками во внутренние адресуемые элементы системы (обычно символы). 
АШОТ затем распределяет определенный объем памяти для содержания данных, 
который будет связан с недавно определенным массивом. 

Вторая строка определяет поведение "времени-выполнения", которое будет 
разделено всеми словами определенными 2АРРАУ, типа РАМ и РЕРІМЕО. Слово 00Е5>, 
заканчивает первую часть определение и начинает вторую часть. Второй 
комментарий здесь указывает, что этот код ожидает индекс и адрес на стеке, и 
возвратит другой адрес. Индекс помещен на стеке вызывающей программой (РАМ в 
примере), в то время как адрес содержимого слова, определенного таким образом 
(область определенная АШОТ) автоматически помещается на вершину стека перед 
выполнением этой части кода. Этот код работает таким образом: 5МАР изменяет 
порядок двух элементов стека, для получения индекса на вершине. 2* СЕШ5 
преобразовывает индекс к внутренним адресуемым элементам как в разделе времени 
компиляции, для выдачи смещения от начала массива. Слово + тогда добавляет 
смещение к адресу начала массива, чтобы дать исполнительный адрес, который 
является желательным результатом. 

Данное основное определение, можно легко изменять, для того чтобы делать более 
сложные вещи. Например, код времени компиляции может быть изменен для 
инициализации массива нулями, пробелами, или любыми другими желательными 
начальными значениями. Размер массива может быть скомпилирован в его начало 
так, чтобы код времени-выполнения мог сравнивать с ним индекс, чтобы 
гарантировать его в пределах диапазона, или полный массив может быть создан 
постоянно находящимся на диске вместо главной памяти. Ни одно из этих изменений 
не затронуло бы использование времени-выполнения, которое мы определили другим 
способом. Это иллюстрирует немного гибкости, доступной с этими определяющими 
словами. 

С.5.8 Пример программирования 

Рисунок С. 1 содержит типичный блок источника РоШН. Он представляет часть 



приложения, которое управляет банком восьми светодиодов, используемых как лампы 
индикатора на приборе, и указывает некоторые из путей, которыми определения 
Рогбб различных видов объединяются в среду прикладной программы. Этот пример 
был кодирован для ЗЮ-Ьиз системы с 8Ѳ88 процессором и миллисекундными часами, 
которые также используются в примере. 

Светодиоды связаны с помощью интерфейса через отдельный 8 битный порт, чей 
адрес 4ѲН . Это местоположение определено как ССШ5ТАІМТ в Строке 1, так чтобы оно 
могло быть упомянуто по имени; если модифицируется адрес, необходимо только 
корректировать значение этой константы. Слово ІЛСНТ5 возвращает этот адрес на 
стеке. Определение ІЛ6НТ берет значение со стека и посылает его на устройство. 
Природа этого значения - битовая маска, чьи биты соответствуют непосредственно 
индивидуальным огням. 
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Таким образом, команда 255 ІЛ6НТ включит все огни, тогда как 0 ІЛ6НТ их всех 
выключит. 

Віоск 180 

0. ( Светодиодное управление ) 

1. НЕХ 40 С0М5ТАІМТ ІЛ6НТ5 ОЕСІМАЦ 

2. : Ш0НТ ( п -- ) ІЛ0НТ5 01ІТРІІТ ; 

3. 

4. ѴАРІАВЦЕ 0ЕІ_АѴ 

5. : 5І_0Ѵ\/ 500 ОЕЦАУ ! ; 

6. : РА5Т 100 0ЕЦАУ ! ; 

7. : С0ЦІІМТ5 256 0 00 I ІЛ6НТ 0Е1_АУ @ М3 Ц00Р ; 

8. 

9. : ЦАМР ( п - ) СРЕАТЕ , 00Е5> ( а -- п ) @ ; 

10. 1 ЦАМР РОМЕР 2 ЦАМР НѴ 4 ЦАМР ТОРСН 

11. 8 ЦАМР 5АМРШМ6 16 ЦАМР ЮІЛМ6 

12. 

13. ѴАРІАВЦЕ ЦАМРЗ 

14. : Т066ЦЕ ( п -- ) ЦАМРЗ § ХОР ОІІР ЦАМРЗ ! Ш6НТ ; 

15. 

Рисунок С.1 - блок источника РогШі, содержащий слова, которые управляют набором 
светодиодов. 

Строки 4-7, содержат простую диагностику типа, которая может быть введена с 
терминала для подтверждения, что все работает. Переменная ОЕЦАУ содержит время 
задержки в миллисекундах - выполнение слова ОЕЦАУ возвращает адрес этой 
переменной. Два значения ОЕЦАУ устанавливаются определениями 5Ц0М и РА5Т, 
используя оператор РогШі ! (произносится "зЦоге") который берет значение и 
адрес, и сохраняет значение по адресу. Определение С0ЦІІМТ5 выполняет цикл от О 
до 255 (циклы РогЦб этого типа ограничены верхним пределом диапазона), посылая 
каждое значение к огням и затем ожидание в течение периода, определенного 
ОЕЦАУ. Слово § (произносится 'ТеЦсб") выбирает значение по адресу, в этом 
случае адрес поставляется ОЕЦАУ. Это значение посылается к М3, которое ждет 
определенного числа миллисекунд. Результат выполнения С0ЦІІМТ5 такой, что огни 
будут считать от 0 до 255 с желательной скоростью. Чтобы выполнить это, введите 
одно слово: 

5Ц0М С0ІЛМТ5 ог РА5Т С0ЦІМТ5 
с терминала. 

Строка 9 предоставляет возможность обозначения индивидуальных ламп. В этом 
приложении они используются как огни индикатора. Слово ЦАМР является 
определяющим словом, которое берет как параметр маску, которая представляет 
специфическую лампу, и компилирует ее как именованный объект. Строки 10, и 11 
содержат пять использований ЦАМР для наименования специфических индикаторов. 




Когда одно из этих слов типа РОМЕР выполнено, маска возвращается на стеке. 
Фактически, поведение определенного значения такое, что когда слово вызвано, 
возвращенное значение идентично поведению РогИп слова СО№ТАІ\ІТ. Мы создавали 
здесь новое определяющее слово, однако, чтобы иллюстрировать, как это было бы 
сделано. 
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Наконец, в строках 13 и 14, мы имеем слова, которые будут управлять световой 
панелью. І_АМР5 является переменной, которая содержит текущее состояние ламп. 
Слово ТОС0І_Е берет маску (которая может быть получена от одного из слов бАМР) и 
изменяет состояние этой специфической лампы, сохраняя результат в І_АМР5 . 

В конце приложения, имена ламп и Т066І_Е - вероятно единственные слова, которые 
будут выполнены непосредственно. Использование там будет, например: 

РОМЕР ТО06І_Е ог 5АМРІЛМ6 Т0С6І_Е 

как соответствующее, всякий раз, когда должны быть изменены системные 
индикаторы. 

Время для компиляции этого блока кода на той системе было приблизительно 
половина секунды, включая время выбора его с диска. Так что это весьма 
практично (и нормальная практика) для программиста, чтобы просто напечатать 
определение и пробовать его немедленно. 

Кроме того, каждый всегда имеет возможность связи с внешними устройствами 
непосредственно. Первая вещь, которую можно было бы делать, когда говорится о 
лампах, будет состоять в том, чтобы напечатать: 

НЕХ РР 40 01ЛР1Л 

и смотреть, включаются ли все лампы. Если нет - предположение, что кое-что 
неправильно с аппаратными средствами, так как эта фраза непосредственно 
передает "полную" маску на устройство. Этот тип прямого взаимодействия полезен 
в приложениях, вовлекающих заказные аппаратные средства, так как он уменьшает 
время отладки аппаратных средств. 

С.6 Мультипрограммные системы 

Мультипрограммные системы Рогіб существовали приблизительно с 1970. Самые 
ранние доступные Рогіб системы распространяли "перехватчики" для этой 
возможности, несмотря на то, что многие не использовали их. Однако основные 
предположения были общеизвестны в сообществе, и существуют значительные точки 
соприкосновения среди этих мультипрограммных систем. Эти системы не только 
языковые процессоры, но содержат также характеристики операционной системы. 
Многие из этих интегрированных систем работают полностью автономно, выполняя 
все необходимые функции операционной системы. 

Некоторые системы РогИп очень быстры, и могут поддерживать, многозадачный режим 
и многопользовательские операции даже на компьютерах, чьи аппаратные средства, 
обычно полагается, неспособны к таким продвинутым операциям. Например, один 
производитель телефонных коммутаторов выполняет 50 задач на 280. Есть несколько 
мультипрограммных изделий для РС, некоторые из которых даже поддерживают много 
пользователей. Даже на компьютерах, которые обычно используются в 
многопользовательских операциях, число пользователей, которые могут быть 
поддержаны, может быть намного больше, чем ожидается. Одно большое приложение 
базы данных выполняющееся на единственном 68000 имеет более чем 100 терминалов 
модифицирующих и запрашивающих эту базу данных, без существенного ухудшения 
свойств. 


Многопользовательские системы могут также поддерживать множество программистов, 
каждый из которых имеет частный словарь, стеки, и набор переменных, управляющих 



этой задачей. Частный словарь связан с общедоступным, реентерабельным словарем, 
содержащим все стандартные функции РогІІі. Частный словарь может использоваться 
для разработки прикладного кода, который может позже быть интегрирован в 
общедоступный словарь. Он может также использоваться для выполнения функций 
требующих текстовый интерпретатор, включая компиляцию и выполнение исходного 
текста. 
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С.7 Конструкционные и организационные соображения 

Также, как выбор строительных материалов имеет сильный эффект на дизайн и 
конструкцию постройки, выбор языка и операционной системы затронет конструкцию 
приложения и решения руководства проектом. 

Традиционно, программные проекты проходят через четыре стадии: анализ, 
конструкция, кодирование, и испытание. Проект РогИп также обязательно включает 
эти действия. РогИп оптимизирован для методологии управления проектом, 
свойственной маленьким группам квалифицированных профессионалов. РогИп поощряет 
итерационный процесс "последовательного макетирования" в котором РогИп высокого 
уровня используется как выполняемая утилита конструкции, с "заглушками", 
заменяющими подпрограммы низшего уровня по мере необходимости (например, для 
аппаратных средств, которые все еще не сформированы). 

Во многих случаях последовательное макетирование может производить 
доброкачественное, более полезное изделие. Как проектные решения, разработчики 
изучают вещи, которые могут вести к лучшей конструкции. Более мудрые решения 
могут быть сделаны, если точные связанные затраты известны, и часто это 
невозможно пока код прототипа не может быть написан и испытан. 

Использование РогИп может сокращать время, требуемое для программной 
разработки, и так же уменьшать уровень усилий, требуемых для обслуживания и 
модификаций в течение жизни изделия. 

С.8 Заключение 

РогИп произвел некоторые замечательные достижения в разнообразии прикладных 
областей. В течение нескольких лет, его принятие выросло быстро, особенно среди 
программистов ищущих способов улучшить их производительность, и менеджеров 
ищущих способы упростить новые проекты программной разработки. 
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Ц. Анализ Совместимости А№ РогИп (информационное приложение) 

До А№ РогіИ, было несколько промышленных стандартов для РогіИ. Наиболее 
влиятельные перечислены здесь в хронологическом порядке, наряду с главными 
различиями между А№ Рогііі и самым современным, Рогііі 83. 

0.1 РІ6 РогІН (приблизительно 1978) 

РІС Рогій был "образцовой" реализацией языка РогІН, разработанного РогІН 
Іпіегезі: бгоир (РІ6). В РІС Рогій, сравнительно мало слов было реализовано на 
процессорно-зависимом машинном языке, остальные слова были реализованы в РогІН 
Модель РІС была размещена на всеобщее достояние, и была перенесена на широкое 
разнообразие компьютерных систем. Поскольку большая часть реализаций РІС РогІП 
была одна и та же на всех машинах, программы, написанные в РІС РогІП, обладали 
существенной степенью переносимости, даже для программ "системного уровня", 
которые непосредственно управляют внутренней организацией системной реализации 
РогІП. 


РІС РогІП реализации имели решающее влияние в увеличении числа людей, 



заинтересованных в использовании Рогіій. Много людей связывают методы 
реализации, воплощенные в РІ6 Рогій модели с "сущностью Рогіій". 

Однако РІ6 Рогіій не обязательно был представителем коммерческой реализации 
Рогіій того же самого периода. Часть наиболее успешных коммерческих систем Рогіій 
использовали методы реализации отличные от "модели" РІ6 Рогіій. 

O . 2 Рогій 79 

Рог1ій-79 Стандарт - результат ряда встреч с 1978 по 198Ѳ, Рогій Зіапсіагсіз Теаш, 
международной группы пользователей Рогій и продавцов (промежуточные версии 
известные как Рогіій 77 и Рогіій 78 были также выпущены группой). 

Рогіій 79 описал набор слов, определенных на 16-бит виртуальной машине, с 
дополнительным кодом (дополнение до двух), не выровненной, линейной адресацией 
байта. Это предписало методику реализации известную как "косвенный шитый код", 
и использование А5СІІ набора символов. 

РогІй-79 Стандарт служил как основание для нескольких общедоступных и 
коммерческих реализаций, некоторые из которых все еще доступны и поддерживаются 
сегодня. 

P. З Рогій 83 

РогІй-83 Стандарт, также Рогіій Зіапсіагсіз Теаш, был выпущен в 1983. Рогіій 83 
предпринял попытку, устранить некоторые из неточностей Рогіій 79. 

Рогіій 83 в большинстве отношений был подобен Рогій 79. Однако Рогіій 83 изменил 
определение нескольких вполне определенных особенностей Рогіій 79. Например, 
поведение округления целочисленного деления, основное значение операндов РІСК и 
РОШ, значение адреса, возвращаемого ', поведение компиляции ', значение "Ігие" 
флага, значение N01, и "последовательное" поведение слов, определенных 
ѴОСАВІІЦАРУ были полностью изменены. Рогій 83 ослабил ограничения реализации 
Рогіій 79, чтобы позволить любой вид шитого кода, но не полностью позволял 
компиляцию чистого машинного кода (это не было специально запрещено, а скорее 
было косвенное последствие другого условия). 
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Много новых реализаций Рогіій были основаны на РогІй-83 Стандарте, но немного 
существует "строго совместимых" реализаций Рог1й-83. 

Хотя несовместимость, следующую из изменений между Рогіій 79 и Рогіій 83, было 
обычно относительно просто устранить, множество преуспевающих продавцов Рогій 
не преобразовало свои реализации, чтобы быть совместимыми с Рогіій 83. Например, 
наиболее преуспевающий коммерческий Рогій для компьютеров Арріе Масіпіозй 
основан на Рогіій 79. 

Ц.4 Недавние события 

С тех пор как был издан РогІй-83 Стандарт, компьютерная промышленность 
подверглась быстрым и глубоким изменениям. Скорость, емкость памяти, и объем 
диска доступных персональных компьютеров увеличились больше чем в 100 раз. 8- 
бит процессоры уступили 16-бит процессорам, и теперь 32-бит процессоры обычное 
явление. 

Операционные системы и среды языков программирования маленьких систем - гораздо 
более мощные, чем они были в начале 80-ых. 

Рынок персонального компьютера изменился от преобладающего рынка "хобби" до 
зрелого делового и коммерческого рынка. 


Улучшенная технология для проектирования заказных микропроцессоров привела к 



разработке многочисленных "чипов Рогіій", компьютеров, оптимизированных для 
выполнения языка Рогіій. 

Рынок для КОМ-базирующихся внедренных управляющих компьютеров существенно 
вырос. 

Чтобы получать полное преимущество этой развивающейся технологии, и лучше 
конкурировать с другими языками программирования, много недавних реализаций 
Рогіій игнорировали некоторые "правила" предыдущих стандартов Рогіій. В 
особенности: 

- 32-разрядные реализации Рогіій теперь обычны. 

- Некоторые системы Рогіій принимают ограничения выравнивания адреса аппаратных 
средств, на которых они работают. 

- Некоторые системы Рогіій используют генерацию чистого кода, генерацию 
микропрограмм, и методы оптимизации, скорее, чем традиционный "шитый код". 

- Некоторые системы Рогіій используют архитектуру сегментированной адресации, 
размещения частей Рогіій "словаря" в различных сегментах. 

- Все более систем Рогіій теперь работают в среде другой "стандартной" 
операционной системы, используя текстовые файлы 05 для исходного текста, 
скорее, чем традиционные Рогіій "блоки". 

- Некоторые системы Рогіій допускают программное обеспечение внешней 
операционной системы, программное обеспечение работы с окнами, концентраторы 
терминала, или каналы связи, для обработки или препроцессорной обработки 
пользовательского ввода, приводя к отступлениям от редактирования ввода, 
пригодности набора символов, и управление поведением экрана, предписанное 
Рогіій 83. 

Конкурентное давление из других языков программирования (преимущественно "С") и 
от других продавцов Рогіій вели продавцов Рогіій к оптимизации, которая не 
соответствует хорошо "модели виртуальной машины" подразумеваемой по 
существующим стандартам Рогіій. 
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Р . 5 А№ Рогіій подход 

А№ Рогіій комитет обратился к серьезной фрагментации семейства Рогіій вызванной 
различиями между Рогіій 79 и Рогіій 83, и отклонениями от любого из этих двух 
промышленных стандартов, вызванными давлением рынка. 

Следовательно, комитет хотел основывать свои решения совместимости не на 
строгом сравнении со Стандартом Рог1ій-83, но вместо этого на рассмотрении 
разнообразия существующих реализаций, особенно тех, что с существенными 
пользовательскими базами и/или значительным успехом на рынке. 

Комитет чувствует что, если А№ Рогіій предпишет строгие требования к 
виртуальной машинной модели, так же как и предыдущие стандарты, тогда много 
разработчиков не выберет исполнение А№ Рогіій. Комитет надеется, что А№ Рогіій 
будет служить для объединения скорее, чем для дальнейшего деления семейства 
Рогіій, и таким образом выбрал обобщение скорее, чем лишение законной силы 
популярных методов реализации. 

Многие из изменений в Рогіій 83 оправданы этим объяснением. Больше всего 
попадает в категорию, что "А№ Рогіій Стандартная Программа не может принимать 
х", где "х" - наименование, вытекающее из виртуальной машинной модели, 
предписанной Рог1ій-83 Стандартом. Комитет чувствует, что эти ограничения 
разумны, особенно полагая, что существенное число существующих реализаций Рогіій 
не реализует правильно Рог1ій-83 виртуальную модель, таким образом, Рог1ій-83 
наименование существует "теоретически" но не "практически". 


Другой взгляд на это - это то, что в то время как А№ Рогіій признает 



разнообразие текущей практики РогІИ, он пытается документировать в этом 
аналогию. В некотором смысле, А№ РогІИ - таким образом "описание 
действительности" скорее чем "предписание для специфической виртуальной 
машины". 

Так как нет никакого предыдущего Атегісап Маііопаі ЗІапсІагсІ для РогІИ, 
требования действий, предписанные разделом 3.4 ХЗ/5Р-9, "Политика и 
Рекомендации", относительно предыдущих стандартов не применяются. 

Следующее обсуждение описывает различия между А№ РогІИ и РогІИ 83. В 
большинстве случаев, РогІН 83 образец РогИп 79 и РІ6 РогІП для целей этого 
обсуждения. Во многих из этих случаев, однако, А№ РогИп более типичный для 
существующего состояния индустрии РогІІі, чем предварительно изданные стандарты. 

0.6.1 Ширина стека 

РогІП 83 определяет, что элементы стека занимают 16 бит. Это включает адреса, 
флаги, и числа. А№ РогІИ определяет, что элементы стека - по крайней мере 16 
бит; фактический размер должен быть документирован реализацией. 

Затрагиваемые слова: вся арифметика, логические и адресующие операторы 

Причина: 32-бит машины становятся банальными. 16-бит система РогІИ на 32-бит 

машине - не конкурентоспособна. 
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Воздействие: Программы, которые принимают 16-бит ширину стека, продолжат 

работать на 16-бит машинах; А№ РогИп не требует другой ширины стека, но просто 
позволяет это. Много программ не будут затронуты (но см. "адресуемый элемент"). 

Переход/Преобразование: Программы, которые используют разрядные маски с 

набором старших бит, вероятно, придется изменить, заменяя определенную 
реализацией константу битовой маски, или процедуру вычисляющую битовую маску 
независимым от ширины стека способом. Вот - некоторые процедуры для построения 
независимых от ширины битовых масок: 

1 СОИЗТАІМТ ШО-ВІТ 

ТКІІЕ 1 РЗНІРТ ІІМѴЕРТ С0№ТАМТ НІ-ВІТ 

: Ю-ВІТ5 ( п -- тазк ) 0 5Ѵ\/АР 0 ?00 1 І_5НІРТ ШО-ВІТ 0Р Ш00Р ; 

: НІ-ВІТ5 ( п -- тазк ) 0 5\л/АР 0 ?Р0 1 П5НІРТ НІ-ВІТ 0Р Ш00Р ; 

Программы, которые зависят от поведения "по модулю '553' ", подразумеваемого в 

операциях 16-бит арифметики, должны быть переписаны, чтобы явно выполнять 
операцию модуля в соответствующих местах. Комитет верит, что такие 
предположения происходят нечасто. 

Примеры: некоторая контрольная сумма или вычисление СРС, некоторые генераторы 
случайного числа и большая часть дробной математики с фиксированной точкой. 

0.6.2 Представление числа 

РогІП 83 определяет представление числа и арифметики дополнительным кодом 
(дополнение до двух). А№ РогІП также позволяет обратный код (дополнение до 
единицы) и величину со знаком. 

Затрагиваемые слова: вся арифметика и логические операторы, 1_00Р, +1_00Р 

Причина: Некоторые компьютеры используют обратный код (дополнение до единицы) 

или величину со знаком. Комитет не желал принуждать реализации РогІП для этих 
машин эмулировать арифметику с дополнительным кодом (дополнение до двух), и 
таким образом подвергаться серьезному ухудшению производительности. Опыт 



некоторых членов комитета с такими машинами указывает, что ограничения 
использования необходимые для поддержки этих представлений чисел не 
обременительны чрезмерно. 

Воздействие: А№ Рогбб Стандартная Программа может объявлять "зависимость от 

окружения для арифметики с дополнительным кодом (дополнение до двух)". Это 
означает иначе, что стандартная программа гарантированно будет работать только 
на машинах с дополнительным кодом (дополнение до двух). Действительно, это - не 
серьезное ограничение, потому что подавляющее большинство современных 
компьютеров использует дополнительный код (дополнение до двух). Комитет знает 
не совместимые с РогІІі-83 реализации для машин с не дополнительным кодом 
(дополнение до двух) в настоящее время, таким образом, существующие Рогбб-83 
программы будут все еще работать на том же классе машин, на котором они в 
настоящее время работают. 

Переход/Преобразование: Существующие программы, желающие воспользоваться 

преимуществом возможности А№ Рогбб Стандартной Системы на машинах не с 
дополнительным кодом (дополнение до двух) могут делать так, устраняя 
использование арифметических операторов для выполнения логических функций, 
получая константы битовой маски от битовых операций как описано в разделе о 
ширине стека, ограничивая диапазон использования чисел без знака до диапазона 
положительных чисел, и используя предусмотренные операторы для преобразования 
из одинарных чисел в двойные числа. 

Р.6.3 Адресуемые элементы 
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Рогбб 83 определяет, что каждый уникальный адрес относится к 8-бит байту в 
памяти. А№ Рогбб определяет, что размер элемента, адресуемого каждым 
уникальным адресом - определенное реализацией, но, по умолчанию, является 
размером одного символа. Рогбб 83 описывает много операций памяти в терминах 
множества байт. А№ Рогбб описывает эти операции в терминах множества символов 
или адресуемых элементов. 

Затрагиваемые слова: те, что с параметром "адресуемого элемента" 

Причина: Некоторые машины, включая наиболее популярные чипы Рогбб, адресуют 

16-бит адреса ячеек памяти вместо 8-бит байтов. 

Воздействие: Программы могут выбирать объявление зависимости от окружения для 

байтовой адресации, и продолжать работать на классе машин, для которых они 
теперь работают. Для реализации Рогбб на адресуемой словом машине, для Рогбб 83 
совместимости, она должна была бы моделировать байтовую адресацию за 
значительную цену в скорости и эффективности памяти. Комитет не знает ни о 
какой такой Рогбб-83 реализации для таких машин, таким образом, зависимость от 
окружения для байтовой адресации не ограничивает Стандартную Программу сверх ее 
текущих фактических ограничений. 

Переход/Преобразование: Новые операторы адресной арифметики СНАК5 и СНАР+ 

должны быть использованы для программ, которые требуют переносимости на машины 
с не байтовой адресацией. Места, где такое преобразование необходимо, могут 
быть идентифицированы, поиском местонахождения слов которые принимают множество 
адресуемых элементов как параметр (например, МОѴЕ , АШОТ). 

Э.6.4 Приращение адреса для ячейки больше не два 

Как последствие Рогбб-83 одновременной спецификации 16-бит ширины стека и 
байтовой адресации, число два могло надежно использоваться в вычислениях адреса 
затрагивающих массивы памяти, содержащие элементы со стека. Так как АМ5 Рогбб 
не требует ни 16-бит ширины стека ни адресации байта, число два больше не 
обязательно соответствует таким вычислениям. 



Затрагиваемые слова: @ ! +! 2+ 2* 2- +І_00Р 


Причина: См. причины для "Адресуемые элементы" и "Ширина стека" 

Воздействие: В этом отношении, существующие программы продолжат работать на 

машинах, где ячейка стека занимает два адресуемых элемента, при сохранении в 
памяти. Это включает большинство машин, для которых в настоящее время 
существуют Рогбй 83 совместимые реализации. В принципе, это также включило бы 
адресуемые 16-бит словами машины с 32-бит шириной стека, но комитет не знает о 
примерах таких машин. 

Переход/Преобразование: Новые операторы адресной арифметики СЕІ_І_5 и СЕІ_І_+ 

должны быть использованы для переносимых программ. Места, где такое 
преобразование необходимо, могут быть идентифицированы, поиском символа "2" и 
определением, действительно ли оно используется как часть вычисления адреса. 
Следующие замены уместны при вычислении адреса: 
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Старое 



Новое 

2+ 

ог 

2 

+ 

СЕІ_І_+ 

2* 

ог 

2 

* 

СЕІ_І_5 

2- 

ог 

2 

- 

1 СЕІ_І_5 - 

2/ ог 

2 

2 

/ 

1 СЕІ_І_5 / 
1 СЕІ_І_5 


Число "2" отдельно иногда используется для вычислений адреса как параметр к 
+1_00Р, когда индекс цикла - адрес. При преобразовании слова 2/, которое 
работает на отрицательных делимых, нужно быть осведомленным об используемом 
методе округления. 

Р.6.5 Выравнивание адреса 

Рогбб 83 не налагает никаких ограничений на выравнивание адресов к какой либо 
границе. А№ РогбИ определяет, что Стандартная Система может требовать 
выравнивание адресов для использования с различными операторами "§" и "!". 

Затрагиваемые слова: ! +! 2! 2@ @ ? , 

Причина: Много компьютеров имеют аппаратные ограничения, которые поддерживают 

использование выровненных адресов. На некоторых машинах, чистые команды доступа 
к памяти вызовут прерывание по исключительной ситуации, если используются с не 
выровненным адресом. Даже на машинах где не выровненные обращения не вызывают 
прерывание по исключительной ситуации, выровненные обращения обычно быстрее. 

Воздействие: Все А№ РогбИ слова, что возвращают адреса, применимые для 

использования с выровненными словами "§" и "!" должны возвращать выровненные 
адреса. В большинстве случаев, это не будет проблемой. Проблемы могут являться 
результатом использования определяемых пользователем структур данных содержащих 
смесь символьных данных и данных размера ячейки. 

Много существующих систем Рогбб, особенно используемых в настоящее время на 
компьютерах с жесткими требованиями выравнивания, уже требуют выравнивание. 
Много существующего кода Рогбб, который в настоящее время используется на таких 
машинах, уже было преобразовано для использования в выровненных средах. 

Переход/Преобразование: Есть два возможных подхода к преобразованию программ 

для использования на системе, требующей выравнивание адреса. 

Самый простой подход состоит в том, чтобы переопределить систему выровненных 
операторов "§" и "!" так, чтобы они не требуовали выравнивания. Например, на 
16-бит машине с прямым порядком байт и байтовой адресацией, не выровненные 





и "!" могли быть определены: 


: § ( асісіг -- х ) РІІР С@ 5Ѵ\/АР СНАР+ С@ 8 І_5НІРТ ОР ; 

: ! ( х асісіг -- ) ОѴЕР 8 Р5НІРТ ОѴЕР СНАР+ С! С! ; 

Эти определения, и подобные для "2§", "2!", и "?" при необходимости, 

могут быть откомпилированы перед не выровненным приложением, которое будет 
тогда работать как ожидается. 

Этот подход может оберегать память, если приложение использует существенное 
количество структур данных, содержащих не выровненные поля. 
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Другой подход состоит в том, чтобы изменить исходный текст приложения для 
устранения не выровненных полей данных. А№ Рогбб слова АІ_І6М и АІЛСМЕР могут 
использоваться для вынужденного выравнивания полей данных. Места, где такое 
выравнивание необходимо, могут быть определены обследованием частей приложения, 
где определены структуры данных (отличные от простых переменных), или методами 
"интеллектуального компилятора" (см. обсуждение "интеллектуального компилятора" 
ниже) . 

Этот подход, вероятно, приведет к более быстрой скорости выполнения приложения, 
при возможном увеличении расхода использования памяти для структур данных. 

Наконец, возможно комбинировать предшествующие методы, идентифицируя точно те 
поля данных, которые не выровнены, и используя "не выровненные" версии 
операторов доступа к памяти только для этих полей. Этот "гибридный" подход 
определяет компромисс между скоростью выполнения и использованием памяти. 

Э. ' . ' Направление округления Ріѵізіоп/тосіиіиз 

Рогбб 79 определяет, что деление округляется к 0 и остаток несет знак делимого. 
Рогбб 83 определяет, что деление округляется к отрицательной бесконечности и 
остаток несет знак делителя. А№ Рогбб позволяет любое поведение для операторов 
деления перечисленных ниже на усмотрение разработчика, и предоставляет пару 
примитивов деления, чтобы позволить пользователю синтезировать любое 
определенное поведение. 

Затрагиваемые слова: / МОЭ /МОЭ */МОЭ */ 

Причина: Различие между поведением деления в РогбИ 79 и Рогбб 83 было 

объектом большого спора, и много реализаций Рогбб не переключались на поведение 
Рогбб 83. Оба варианта имеют шумных сторонников, цитирующих требования к 
приложениям и аргументы эффективности выполнения с обеих сторон. После обширных 
дебатов охватывающих много встреч, комитет был не способен достигнуть согласия 
в выборе того или иного поведения, и выбрал разрешение любого поведения как 
значения по умолчанию, в тоже время предусматривая пользовательские средства 
для явного использования любого поведения по необходимости. Так как 
разработчикам разрешен выбор любого поведения, не требуется изменять поведение, 
показанное их текущими системами, таким образом, сохраняя правильное 
функционирование существующих программ, которые работают на этих системах и 
зависят от специфического поведения. Новые реализации могли выбирать поведение, 
которое поддерживается родной системой команд СРІІ, таким образом максимизируя 
скорость выполнения, или могли выбирать поведение, которое больше соответствует 
предназначенной прикладной области системы. 

Воздействие: Проблема затрагивает только программы, которые используют 

отрицательное делимое с положительным делителем, или положительное делимое с 
отрицательным делителем. Огромное большинство использования деления происходят, 
с положительным делимым и положительным делителем; в этом случае, результат 
один и тот же для обоих разрешенных поведений деления. 



Переход/Преобразование: Для программ, которые требуют специфического 

поведения округления с операндами деления смешанного знака, операторы деления, 
используемые в программе, могут быть переопределены в терминах одного из новых 
примитивов деления А№ Рогіііі 5М/РЕМ (симметричное деление, то есть округление к 
нулю) или РМ/МСЮ (минимальное деление, то есть, округление к отрицательной 
бесконечности). Тогда программа может быть перетранслирована без изменения. 
Например, операторы деления стиля РогІП 83 могут быть определены: 
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НОСТИ 






Рогіііі 

83 

определил 

, что 

множество 

"компилирующих слов" являются "немедленного 


исполнения", означая что они выполняются вместо компилирования в течение 
компиляции. А№ РогІИ менее конкретен относительно большинства этих слов, 
заявляя, что их поведение определено только в течение компиляции, и определяя 
их результат скорее, чем их специфические действия во время компиляции. 

Чтобы заставить компилироваться слово, которое обычно выполнилось бы, РогІИ 83, 
предусматривал слова СОМРШЕ используемое со словами не немедленного 
исполнения, и [СОМРШЕ] используемое со словами немедленного исполнения. А№ 
Рогіііі предусматривает единственное слово Р05ТР0МЕ , которое используется и с 
немедленного исполнения и с не немедленного исполнения словами, автоматически 
выбирая соответствующее поведение. 

Затрагиваемые слова: СОМРШЕ [СОМРШЕ] ['] ' 

Причина: Обозначение специфических слов как немедленного исполнения или нет, 

зависит от методики реализации, выбранной для системы Рогіііі. В традиционных 
реализациях "шитого кода", выбор был вообще довольно ясный (с единственным 
исключением слова І_ЕАѴЕ) , и стандарт мог определить какие слова должны быть 
немедленного исполнения. Однако, некоторые в настоящее время популярные методы 
реализации, типа генерация чистого кода с оптимизацией, требуют атрибута 
немедленного исполнения на наборе слов отличном от набора слов немедленного 
исполнения реализации шитого кода. А№ РогІИ, подтверждая законность этих 
других методов реализации, определяет атрибут немедленного исполнения в таких 
немногих случаях, насколько это возможно. 

Когда состав набора слов немедленного исполнения неясен, решение использовать 
ли СОМРШЕ или [СОМРШЕ], становится неясным. Следовательно, А№ РогІИ 
предоставляет "универсальное" слово замены Р05ТР0МЕ, которое обслуживает цели 
огромного большинства применений СОМРШЕ и [СОМРШЕ] без требования знания 
пользователем, действительно ли "отложенное" слово немедленного исполнения. 

Точно так же использование ' и ['] с компилирующими словами не ясно, если 
точное поведение компиляции этих слов не определено, так что А№ РогІИ не 
разрешает Стандартной Программе использовать 1 или ['] с компилирующими 
словами. 

Традиционное (не немедленного исполнения) определение слова СОМРШЕ имеет 
дополнительную проблему. Его традиционное определение принимает методику 
реализации шитого кода, и его поведение может быть должным образом описано 
только в этом контексте. В контексте А№ РогІП, который разрешает другие методы 
реализации в дополнение к шитому коду, очень трудно, если не невозможно описать 
поведение традиционного СОМРШЕ. Скорее чем изменить его поведение, и таким 
образом нарушить существующий код, А№ Рогіііі не включает слово СОМРШЕ. Это 




позволяет существующим реализациям продолжить снабжать слово СОМРШЕ его 
традиционным поведением, если это соответствует реализации. 
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Воздействие: [СОМРШЕ] остается в А№ Рогіб, так как его надлежащее 

использование не зависит от знания того, действительно ли слово является 
немедленного исполнения (Использование [СОМРШЕ] со словом не немедленного 
исполнения является, и всегда было пустой командой). Действительно ли Вы должны 
использовать [СОМРШЕ] требует знания того, действительно ли его целевое слово 
является словом немедленного исполнения, но использовать [СОМРШЕ] всегда 
безопасно. [СОМРШЕ] - больше не в (требуемом) основном наборе слов, будучи 
перемещенное в Расширение Основного набора слов, но комитет предупреждает, что 
большинство продавцов поставят его, так или иначе. 

Почти во всех случаях, правильно заменить [СОМРШЕ] и СОМРШЕ на РОЗТРОИЕ. 
Использования [СОМРШЕ] и СОМРШЕ, которые - "бессмысленно" менять на Р05ТР0ИЕ 
, являются весьма редкими, и относятся следующим к двум категориям: 

a) Использование [СОМРШЕ] с не немедленного исполнения словами. Это иногда 
делается со словами ' (Иск) (которое было немедленного исполнения в РогбН 79, 
но не в РогІН 83) и І_ЕАѴЕ (которое было немедленного исполнения в Рогбб 83 но 
не в Рогбб 79), чтобы вынуждать компиляцию этих слов без относительно к тому, 
используете ли Вы Рогіб 79 или Рогіб 83 систему. 

b) Использование фразы СОМРШЕ [СОМРШЕ] <слово немедленного исполнения> для 
"двойного розбропе" слова немедленного исполнения. 

Переход/Преобразование: Много АМЗ Рогіб реализаций продолжит реализовывать 

оба [СОМРШЕ] и СОМРШЕ в формах, совместимых с существующим использованием. В 
этих средах, нет необходимости в преобразовании. 

Для полной переносимости, использование СОМРШЕ и [СОМРШЕ] должно быть 
заменено на Р05ТР0ИЕ, кроме редких случаев обозначенных выше. Использование 
[СОМРШЕ] со словами не немедленного исполнения, может быть оставлено как есть, 
и программа может объявить, что требуется слово [СОМРШЕ] из Расширения 
Основного набора слов, или [СОМРШЕ] перед словом не немедленного исполнения 
может быть просто удалено, если целевое слово, как известно, является не 
немедленного исполнения. 

Использование фразы СОМРШЕ [СОМРШЕ] <слово немедленного исполнения> может 
быть обработано, представляя "промежуточное слово" (XX в примере ниже) и затем 
выполняя Р05ТР0МЕ с этим словом. Например: 

: АВС СОМРШЕ [СОМРШЕ] ІР ; 

изменения: 

: XX Р03ТР0МЕ ІР ; 

: АВС Р05ТР0ИЕ XX ; 

Нестандартный случай может происходить в программах, которые "выключают 
состояние компиляции" для явной компиляции потока в словарь после СОМРШЕ. 
Например: 

: ХѴ2 СОМРШЕ [ 1 АВС , ] ; 

Это сильно зависит от точного знания, как работают СОМРШЕ и реализация шитого 
кода. Случаи подобно этому не могут быть обработаны механически; они должны 
быть транслированы с точным пониманием того, что делает код, и переписыванием 
этого раздела согласно АМЗ РогІИ ограничениям. 

Используйте фразу Р03ТР0МЕ [СОМРШЕ] для замены [СОМРШЕ] [СОМРШЕ] . 
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O. 6.8 Входной набор символов 

Рогіііі 83 определяет, что полный 7-бит набор символов А5СІІ доступен через КЕУ. 
АІ\І5 Рогій ограничивает его графическими символами набора А5СІІ, с кодами от йех 
20 до йех 7Е включительно. 

Затрагиваемые слова: КЕУ 

Причина: Много системных сред "потребляют" некоторые управляющие символы для 

таких целей как редактирование ввода, управление заданиями, или управление 
потоком данных. Реализация Рогіій не всегда может управлять этим системным 
поведением. 

Воздействие: Стандартные Программы, которые требуют способности получить 

специфические управляющие символы через КЕУ должны объявить зависимость от 
окружения для входного набора символов. 

Переход/Преобразование: Для максимальной переносимости, программы должны 

ограничить их требуемый входной набор символов только графическими символами. 
Управляющие символы могут быть обработаны, если доступны, но полные 
функциональные возможности программы должны быть доступны с использованием 
только графических символов. 

Как определено выше, может быть объявлена зависимость от окружения на входном 
наборе символов. Даже в этом случае, рекомендуется, чтобы программа избегала 
требования особенно неприятных управляющих символов, типа соп1;го1-5 и сопСгоІ-ф 
(часто используемых для управления потоком, иногда аппаратными средствами 
связи, чье присутствие может быть трудно обнаруживаемо), АЗСІІ N111- (трудно 
напечатать на многих клавиатурах), и различий между возвратом каретки и 
переводом строки (некоторые системы транслируют возвраты каретки в переводы 
строки, или наоборот). 

P. 6.9 Сдвиги с ІІМ/МСЮ 

Данная РогСй-83 природа дополнительного кода (дополнение до двух), и его 
требование минимального деления (округление к минус бесконечности), сдвиг 
эквивалентен делению. Также, представление дополнительного кода (дополнение до 
двух) подразумевает, что деление без знака величиной два эквивалентно 
логическому правому сдвигу, так ІІМ/МСЮ могло использоваться для исполнения 
логического правого сдвига. 

Затрагиваемые слова: ІІМ/МСЮ 

Причина: Проблема с ІІМ/МСЮ - это результат разрешения представления числа не 

дополнительным кодом (дополнение до двух), как уже описано. 

АІМ5 Рогій предоставляет слова І_5НІРТ и Р5НІРТ для выполнения логических 
сдвигов. Это - обычно более эффективно, и конечно более наглядно, чем 
использование ІІМ/МСЮ для логического сдвига. 

Воздействие: Программы, выполняющиеся на АІ\І5 Рогіій системах с арифметикой 

дополнительного кода (дополнение до двух) (большинство машин), не будут 
испытывать никакой несовместимости с ІІМ/МСЮ. Существующие Рог1:й-83 Стандартные 
программы, предназначенные для работы на машинах с не дополнительным кодом 
(дополнение до двух), не смогут использовать ІІМ/МСЮ для смещения на АІ\І5 РогСй 
системе с не дополнительным кодом (дополнение до двух). Это не должно затронуть 
значительное число существующих программ (возможно ни какие), так как комитет 
не знает ни о каких существующих Рог1:й-83 реализациях на машинах с не 
дополнительным кодом (дополнение до двух). 



233 


Переход/Преобразование: Программа, которая требует, чтобы ІІМ/МСЮ вел себя как 

операция сдвига, может объявить зависимость от окружения на арифметике 
дополнительного кода (дополнение до двух). 

Программа, которая не может объявить зависимость от окружения на арифметике 
дополнительного кода (дополнение до двух) может требовать редактирования для 
замены несовместимого использования ІІМ/МСЮ другими операторами, определенными в 
пределах приложения. 

Р.6.1Ѳ Словари / списки слов 

АІМ5 РогІП не определяет слова ѴОСАВІШАПѴ, СОІМТЕХТ, и СІІРРЕІМТ, которые 
существовали в Рогіііі 83. Вместо этого, АІМЗ РогСИ определяет примитивный набор 
слов для спецификации порядка поиска и управления порядком поиска, включая 
слова, которые не существовали ни в каком предыдущем стандарте. 

Рог1:Іі-83 "А1_50/0І\ІІ_Ѵ" экспериментальный набор слов порядка поиска определен 
главным образом как часть расширения АІМ5 РогІП набора слов Порядка Поиска. 

Затрагиваемые слова: ѴОСАВІШАРУ СОІМТЕХТ СІІРКЕІМТ 

Причина: Словари - область больших расхождений среди существующих систем. 

Рассматривая системы главных продавцов и предыдущие стандарты, есть, по крайней 
мере, 5 различных и взаимно несовместимых поведений слов, определенных 
ѴОСАВІШАРУ . Рогііі 83 предпринял шаг в направлении "спецификации порядка поиска 
времени-выполнения", опускаясь к определению специфических отношений между 
иерархией откомпилированных словарей и порядком поиска времени-выполнения. 

Рогіііі 83 также определил экспериментальный механизм для спецификации порядка 
поиска времени-выполнения, АІ_50/0ІМІ_Ѵ схема. АІ_50/0ІМІ_Ѵ были реализованы в 
многочисленных системах, и достигли некоторой меры популярности в семействе 
Рогіііі . 

Однако, несколько продавцов отказываются реализовать это, цитируя технические 
ограничения. В попытке адресовать эти ограничения и таким образом надеясь 
сделать АІ_50/0ІМІ_Ѵ более приемлемыми для этой критики, комитет определил простой 
"примитивный набор слов", который не только устраняет некоторые из возражений 
по АІ_50/ОІ\ІІ_Ѵ, но также и предусматривает достаточную возможность реализации 
АІ_50/0І\ІІ_Ѵ и всех других наборов слов порядка поиска, которые в настоящее время 
популярны. 

Рогіііі 83 АІ_50/0І\ІІ_Ѵ набор слов предусмотрен как дополнительное расширение к 
набору слов порядка поиска. Это предоставляет разработчикам, которые так 
склонны предоставлять этот набор слов, четкое стандартное поведение, но не 
заставляет разработчиков так делать. Некоторые продавцы публично заявили, что 
они не будут реализовывать АІ_50/0МІ_Ѵ, независимо ни от чего, и один главный 
продавец заявил нежелание реализовать АІ\І5 Еогіііі вообще, если АІ_50/0І\ІІ_Ѵ получит 
мандат. Комитет чувствует, что его действия благоразумны, определяя АІ_50/0І\ІІ_Ѵ 
по возможности без наказа включения его во все системы, и также предусматривая 
примитивный набор слов порядка поиска, который продавцы может быть, более 
вероятно реализуют, и который может использоваться для синтеза АІ_50/0І\ІІ_Ѵ. 

Переход/Преобразование: Так как РогСП 83 не указывал точную семантику для 

ѴОСАВІЛАРУ, существующие РогіІі-83 Стандартные программы не могут использовать 
это кроме как тривиальным способом. Программы могут объявить зависимость от 
существования набора слов Порядка Поиска, и могут реализовать любую семантику, 
требующуюся для использования этих примитивов набора слов. Рогіііі 83 программы 
которые требуют АІ_50/0І\ІІ_У могут объявлять зависимость от Расширения набора слов 
Порядка Поиска, или могут реализовать расширения в терминах набора слов Порядка 
Поиска непосредственно. 
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0.6.11 Воздействие мультипрограммирования 

Рогіій 83 отметил слова с "воздействием мультипрограммирования" символом "М" в 
первых строках их описаний. АІМ5 Рогіій удалил обозначение "М" из описания слова, 
перемещая обсуждение воздействия мультипрограммирования в это ненормативное 
приложение. 

Затрагиваемые слова: Ни одно 

Причина: Значение "воздействие мультипрограммирования" является точным только 

в контексте специфической модели для мультипрограммирования. Хотя много систем 
Рогіій предусматривают свойства мультипрограммирования, использующие 
специфическую карусель, кооперативность, модель совместного использования 
блочных буферов, эта модель - не универсальна. Даже принимая классическую 
модель, "М" обозначения не содержали достаточно информации, чтобы дать 
возможность написания приложений которые взаимодействуют в мультипрограммной 
системе. 

Практически говоря, "М" обозначения в Рогіій 83 служат для документирования 
правил использования адресов блочных буферов в мультипрограммных системах. Эти 
адреса, часто становятся бессмысленными после того, как задача оставляет СРІІ по 
какой либо причине, наиболее часто с целью выполнения ввода-вывода, ожидая 
события, или добровольного деления ресурсов СРІІ используя слово РАІІ5Е. Было 
существенно, что переносимые приложения уважают эти правила использования, 
делая возможным выполнение их на мультипрограммных системах; отказ твердо 
придерживаться правил, мог легко поставить под угрозу целостность других 
приложений, выполняющихся на этих системах так же как приложений фактически с 
ошибкой. Таким образом, "М" появилось на всех словах, которые созданы, чтобы 
покинуть СРІІ, с пониманием, что другие слова НИКОГДА не оставляют его. 

Эти правила использования были явно зарегистрированы в Блочном наборе слов, где 
они уместны. "М" обозначения были полностью удалены. 

Воздействие: Практически, нет. 

В смысле что любое приложение, которое зависит от мультипрограммирования, 
должно состоять из, по крайней мере, двух задач, которые совместно используют 
некоторый ресурс и связываются между собой, РогГй 83 не содержал достаточно 
информации, чтобы дать возможность написания стандартной программы, которая 
ЗАВИСИЛА от мультипрограммирования. Это - также истинно для АІМ5 РоПй. 

Не мультипрограммные приложения в РогГй 83 требовались для признания правил 
использования для ВЮСК так, чтобы они могли быть выполнены должным образом на 
мультипрограммных системах. Тот же самое истинно для АІ\І5 Рогіій. 

Единственное различие - метод документирования, используемый для определения 
правил использования В1_0СК. Технический Комитет верит, что текущий метод более 
ясен, чем концепция "воздействия мультипрограммирования". 

Переход/Преобразование: Нет необходимости. 

0.6.12 Слова, не представленные в исполняемой форме 
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АІ\І5 Рогій позволяет реализациям поставлять некоторые слова в исходном коде или 
форме "загрузки при необходимости", скорее чем требует, чтобы все снабжаемые 
слова были доступны без дополнительных действий программиста. 

Затрагиваемые слова: Все 


Причина: 


Системы Рогій часто используются в средах, где пространство памяти 



пользуется большим спросом. Каждое слово, включенное в систему в выполнимой 
форме, потребляет пространство памяти. Комитет верит, что разрешение 
стандартным словам быть предоставленными в исходной форме, увеличит вероятность 
того, что разработчики предоставят законченные А№ Рогбб реализации даже в 
системах, разработанных для использования в ограниченных средах. 

Воздействие: Чтобы использовать Стандартную Программу с заданной А№ Рогбй 

реализацией, может быть необходимо предшествующее программе зависящее от 
реализации "предисловие", чтобы делать слова "в исходной форме" выполняемыми. 
Это подобно методам, как другие машинные языки требуют выбрать библиотечные 
подпрограммы, необходимые для специфического приложения. 

На языках подобных С, цель устранения ненужных подпрограмм из отображения 
памяти приложения обычно выполняется предоставлением библиотек подпрограмм, и 
использованием программы "компоновщика", чтобы включить только необходимые 
подпрограммы в выполнимое приложение. Метод вызова и управления компоновщиком - 
вне контекста определения языка. 

Переход/Преобразование: Перед компилированием программы, программист может 

быть должен выполнить некоторое действие, чтобы сделать слова, требуемые этой 
программе, доступными для выполнения. 
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Е. Руководство по переносимости А№ Рогбб (информационное приложение) 

Е.1 Введение 

Наиболее популярные архитектуры, используемые для реализации Рогбб, имели 
память с байтовой адресацией, 16-бит операции, и представление числа с 
дополнительным кодом (дополнение до двух). РогбИ-вЗ Стандарт диктует, что эти 
специфические особенности должны присутствовать в РогбІі-83 Стандартной системе, 
и что РогІб-83 программы могут эксплуатировать эти возможности свободно. 

Однако есть много животных в архитектурных джунглях, которые являются бит 
адресуемыми или ячейкой адресуемыми, или предпочитают 32-бит операции, или 
представляют числа в обратном коде (дополнение до единицы). Так как одна из 
сильных сторон Рогбб - это его пригодность в "странных" средах на "необычных" 
аппаратных средствах со "специфическими" возможностями, важно, что Стандартный 
Рогбб также работает на этих машинах. 

Первичная цель АМ5 РогбИ Стандарта состоит в том, чтобы увеличить типы машин, 
которые могут поддерживать Стандартный Рогбб. Это выполнено, допущением 
некоторых ключевых терминов Рогбб быть определенными реализацией (например, 
насколько большая - ячейка?) и, предусмотрением Рогбб операторов (слов) которые 
скрывают реализацию. Это освобождает разработчика от необходимости создавать 
систему Рогбб, которая наиболее эффективно использует родные аппаратные 
средства. Машинно-независимые операторы, вместе с некоторой дисциплиной 
программирования, дают возможность программисту писать программы Рогій, которые 
работают на широком разнообразии машин. 

Остаток от этого Приложения предоставляет рекомендации для записи переносимых 
А№ Рогій программ. Первый раздел описывает способы делать программы аппаратно 
независимыми. Это трудно для кого-то знакомого с только одной машинной 
архитектурой, чтобы вообразить проблемы, вызванные транспортировкой программ 
между несходными машинами. Поэтому даются примеры специфических архитектур с их 
соответствующими проблемами. Второй раздел описывает предположения о 
реализациях Рогбй, которые делают много программистов, но на которые нельзя 
полагаться в переносимой программе. 

Е.2 Аппаратные особенности 

Е.2.1 Абстракция данных/памяти 



Данные и память - камни и строительный раствор конструкции программы. К 
сожалению, каждый компьютер обрабатывает данные и память различно. Стандарт А№ 
Рогіііі Систем дает определения данных и памяти, которые применяются к широкому 
разнообразию компьютеров. Эти определения дают нам способ говорить об общих 
элементах данных и памяти, в то же время игнорируя подробности специфических 
аппаратных средств. Точно так же А№ Рогіііі программы, которые используют данные 
и память способами соответствующими этим определениям, могут также игнорировать 
аппаратные подробности. Следующие разделы обсуждают определения и описывают, 
как записать программы, которые не зависят от особенностей данных/памяти 
различных компьютеров. 

Е.2.2 Определения 

Три термина, определены А№ Рогіііі - адресуемый элемент, ячейка, и символ. 
Адресное пространство из А№ РогІіИ системы разделено на массив адресуемых 
элементов; адресуемый элемент- это самая маленькая коллекция битов, которые 
могут быть адресованы. Другими словами, адресуемый элемент- это число битов, 
охватываемых адресами асісіг и асісіг+і. Наиболее распространенные машины 
используют 8-бит адресуемые элементы. Такие "байт адресуемые" машины включают 
Іпіеі 8086 и Моііогоіа 68000 семейства. 
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Однако существуют другие размеры адресуемых элементов. Есть машины, которые 
являются бит адресуемыми и машины, которые являются адресуемыми 4-бит 
полубайтом. Есть также машины с адресуемыми элементами больше 8-бит. Например, 
есть несколько Рогіб-іп-багсіиаге компьютеров - ячейкой адресуемых. 

Ячейка - фундаментальный тип данных системы РогІІі. Ячейка может быть целым 
числом одна-ячейка или адресом памяти. Параметры Рог^Н и стеки возвратов - это 
стеки ячеек. Рог^Н 83 определяет, что ячейка - 16- бит. В А№ Рогіб размер 
ячейки - это число определенных реализацией адресуемых элементов. Таким 
образом, А№ Рогіііі реализованный на 16-бит микропроцессоре может использовать 
16-бит ячейку, и реализация на 32-бит машине может использовать 32-бит ячейку. 
Также 18-бит машины, 36-бит машины, и т.д., могли поддерживать А№ Рог^Н 
системы с 18 или 36-бит ячейками соответственно. Во всех этих системах, 01ІР 
делает одну и ту же вещь: оно дублирует вершину стека данных. ! (память) ведет 
себя соответственно также: учитывая две ячейки данных на стеке, оно сохраняет 
вторую ячейку по адресу ячейки памяти обозначенному верхней ячейкой. 

Точно так же было обобщено определение символа, чтобы быть определенным 
реализацией числом адресуемых элементов (но, по крайней мере, восемь бит). Это 
устраняет потребность для разработчика Рогіб предусматривать 8-бит символы на 
процессорах, где это не так. Например, на 18-бит машине с 9-бит адресуемым 
элементом, 9-бит символ был бы наиболее удобен. С тех пор, по определению, Вы 
не можете адресовать что - ни будь меньшее чем адресуемый элемент, символ 
должен быть, по крайней мере, столь же большой как адресуемый элемент. Это 
приведет к большим символам на машинах с большими адресуемыми элементами. Как 
пример - машина с 16-бит адресуемой ячейкой, где 16-бит символ имеет больше 
смысла. 

Е.2.3 Адресация памяти 

А№ Рогіб устраняет много проблем переносимости, используя вышеупомянутые 
определения. Одна из наиболее обычных проблем переносимости - это адресация 
последовательных ячеек в памяти. Имея адрес ячейки памяти, как Вы находите 
адрес следующей ячейки? В Рог^б 83 это просто: 2 + . Этот код предполагает, что 
память адресуется элементами по 8-бит (байт) и ячейка - 16-бит шириной. На 
машине с байтовой адресацией и с 32-бит ячейками, код для нахождения следующей 
ячейки был бы 4 + . Код был бы 1+ на ячейкой адресуемом процессоре, и 16 + на 
бит адресуемом процессоре с 16-бит ячейкой. А№ Рогіб предоставляет оператор 
следующей ячейки именуемый СЕІ_І_+ , который может использоваться во всех этих 



случаях. Задаваясь адресом, СЕІ_І_+ корректирует адрес размером ячейки 
(измеряемым в адресуемых элементах). Связанная проблема - это адресация массива 
ячеек в произвольном порядке. Определяющее слово для создания массива ячеек, 
используя РоШН 83 было бы: 

: АРРАУ СРЕАТЕ 2* АШОТ 00ЕЗ> ЗМАР 2* + ; 

Использование 2* для масштабирования индекса массива предполагает байт 
адресацию и 16-бит ячейки. Как в примере выше, для различных машин были бы 
необходимы различные версии кода. АИЗ РоШй предоставляет переносимый оператор 
масштабирования именуемый СЕІ_І_5 . Учитывая число п, СЕІ_І_5 возвращает число 
адресуемых элементов, необходимых для получения п ячеек. Переносимое 
определение массива таково: 

: АРРАУ СРЕАТЕ СЕІ_І_5 АШОТ 
Р0ЕЗ> 5Ѵ\/АР СЕШ5 + ; 
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Есть также проблемы переносимости с адресацией массивов символов. В РоШй 83 (и 
в наиболее обычных АМЗ РогІП реализациях), размер символа будет равняться 
размеру адресуемого элемента. Следовательно, адреса последовательных символов в 
памяти могут быть найдены, используя 1+ и масштабирование индексов в символьном 
массиве - это пустая команда (то есть, 1 *). Однако есть случаи, где символ 
больше чем адресуемый элемент. Примеры включают (1) системы с маленькими 
адресуемыми элементами (например, бит- и полубайт- адресуемые системы), и (2) 
системы с большими наборами символов (например, 16-бит символы на байт 
адресуемой машине) . СНАР+ и СНАРЗ операторы, аналогичные СЕШ+ и СЕШ5 доступны 
для разрешения максимальной переносимости. 

АИЗ РогІП обобщает определение некоторых слов РоШИ, которые работают на 
участках памяти с использованием адресуемых элементов. Один пример - АШОТ. 
Приписыванием перед АШОТ соответствующего масштабирующего оператора (СЕШ5, 
СНАРЗ, и т.д.), может быть распределено пространство для любой желательной 
структуры данных (см. определение массива выше). Например: 

СРЕАТЕ АВІІРРЕР 5 СНАРЗ АШОТ (назначает 5 символьный буфер) 

Слово блочного перемещения памяти также использует адресуемые элементы: 

зоигсе сіезііпаііоп 8 СЕШ5 МОѴЕ (перемещает 8 ячеек) 

Е.2.4 Проблемы выравнивания 

Не все адреса созданы равными. Много процессоров имеют ограничения на адреса, 
которые могут использоваться командами доступа к памяти. Этот Стандарт не 
требует от разработчика АИЗ РоШИ делать выравнивание прозрачным; напротив, он 
требует (в Разделе 3.3.3.1 Выравнивание адреса), что АИЗ РоШП программа 
принимает, что может требоваться выравнивание символа и ячейки. 

Одна из наиболее обычных проблем, вызванных ограничениями выравнивания, состоит 
в создании таблиц содержащих и символы и ячейки. Когда , (запятая) или С, 
используется для инициализации таблицы, данные сохраняются по указателю области 
данных. Следовательно, они должны быть соответственно выровнены. Например, 
непереносимое определение таблицы было бы: 

СРЕАТЕ АТАВІ_Е 1 С, X , 2 С, У , 

На машине, которая ограничивает 16-бит выборки по четным адресам, СРЕАТЕ 
оставил бы указатель области данных на четном адресе, 1 С, делало бы указатель 
области данных нечетным, и , (запятая) нарушила бы ограничение адреса, сохраняя 
X по нечетному адресу. Переносимый способ создания таблицы: 



СРЕАТЕ АТАВІ.Е 1 С, АІ_І6М X , 2 С, АІЛ6М У , 


АІЛСМ корректирует указатель области данных на первый выровненный адрес больший 
чем или равный его текущему адресу. Выровненный адрес подходит для сохранения 
или выборки символов, ячеек, пар-ячеек, или чисел две-ячейки. 

После инициализации таблицы, мы также хотели бы читать значения из таблицы. 
Например, предположите, что мы хотим выбрать первую ячейку X , из таблицы. 
АТАВЦЕ СНАП+ дает адрес первой вещи после символа. Однако это не может быть 
адрес из X , так как мы выровняли указатель словаря между С, и , . Переносимый 
путь получения адреса X такой: 
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АТАВЦЕ СНАР+ АІЛ6Ш0 

АІЛСШО корректирует адрес на вершине стека к первому выровненному адресу 
большему чем или равному его текущему значению. 

Е.З Представление числа 

Различные компьютеры представляют числа различными способами. Понимание этих 
различий может помочь программисту избежать написания программы, которая 
зависит от частного представления. 

Е.3.1 Обратный порядок байт против прямого порядка байт 

Битовые составляющие числа в памяти сохраняются в различном порядке на 
различных машинах. Некоторые машины помещают самую старшую часть числа по 
адресу в памяти, и младшие части после ней в более высоких адресах. Другие 
машины делают напротив - самая младшая часть сохраняется по самому меньшему 
адресу. Например, следующий код для 16-бит 8086 РогШ "прямой порядок байт" 
произвел бы ответ 34 (Пех): 

ѴАРІАВБЕ Р00 НЕХ 1234 Р00 ! Р00 С@ 

Тот же самый код на 16-бит 68000 РогІИ "обратный порядок байт" произвел бы 
ответ 12 (Нех). Переносимая программа не может использовать представление числа 
в памяти. 

Связанная проблема - это представление в памяти пары-ячеек и чисел две-ячейки. 
Когда пара-ячеек перемещается со стека в память с помощью 2! , ячейка, которая 
была на вершине стека, помещается по меньшему адресу памяти. Это полезно и 
разумно для манипулирования отдельными ячейками, когда они находятся в памяти. 

Е.З. 2 Организация АШ 

Различные компьютеры используют различный набор двоичных разрядов для 
представления целых чисел. Варианты включают двоичные представления 
(дополнительный код (дополнение до двух), обратный код (дополнение до единицы), 
величина со знаком, и т.д.), и десятичные представления (ВСО, и т.д.). Каждый 
из этих форматов создает преимущества и недостатки в конструкции арифметико- 
логического элемента компьютера (АШ) . Наиболее часто используемое 
представление, дополнительный код (дополнение до двух), является популярным из- 
за простоты его алгоритмов суммирования и вычитания. 

Программисты, которые выросли на машинах с дополнительным кодом (дополнение до 
двух), имеют тенденцию стать зависимыми от их представления чисел и брать для 
предоставления некоторые свойства этого представления. Например, хитрость для 
нахождения остатка от числа, разделенного величиной два - это маскировать 
некоторые биты с помощью АШ. Обычное приложение этой хитрости - это проверить 
число на нечетность, используя 1 АШ. Однако это не будет работать на машине с 
обратным кодом (дополнение до единицы), если число отрицательное (переносимая 



методика - 2 МСЮ) . 
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Остаток от этого раздела - (не исчерпывающий) список вещей для наблюдения за 
тем, когда желательна переносимость между машинами с двоичными представлениями 
отличными от дополнительного кода (дополнение до двух). 

Преобразовать число одна-ячейка в число две-ячейки, А№ Рогіій предусматривает 
оператор 5>0. Чтобы преобразовать число две-ячейки в одну-ячейку, программисты 
Рогіій имеют традиционное использование ОПОР. Однако эта уловка не работает на 
машинах величины со знаком. Для переносимости доступен оператор 0>5. 
Преобразование числа одна-ячейка без знака в число две-ячейки может быть 
сделано переносимо, помещением нуля на стек. 

Е. 4 Реализация Рогіій системы 

В продолжение истории Рогіій, было разработано удивительное разнообразие методов 
реализации. А№ Рогіій Стандарт поощряет это разнообразие и следовательно 
ограничивает предположения пользователя, которые он может делать об основной 
реализации А№ Рогіій системы. Пользователи конкретной реализации Рогіій часто 
привыкают к аспектам реализации и предполагают, что они обычны для всех Рогіій. 
Этот раздел указывает многие из этих неправильных предположений. 

Е.4.1 Определения 

Традиционно, определения Рогіій состояли из имени слова Рогіій, связи поиска в 
словаре, данных, описывающих, как выполнять определение, и параметров, 
непосредственно описывающих определение. Эти компоненты названы именем, связью, 
кодом, и полем параметров. Не было найдено никакого метода для доступа к этим 
полям, который работал бы поперек всех используемых в настоящее время 
реализаций Рогіій. Поэтому, А№ Рогіій строго ограничивает то, как могут 
использоваться поля. Определенно, переносимая А№ Рогіій программа не может 
использовать имя, связь, или поле кода произвольно. Использование поля 
параметров (для ясности переименованное в поле данных) ограничено операциями, 
описанными ниже. 

Только слова, определенные СПЕАТЕ или другими определяющими словами, которые 
вызывают СПЕАТЕ, имеют поля данных. Другие определяющие слова в Стандарте 
( ѴАРІАВЙЕ, С0М5ТАІМТ, :, и т.д.) не могут быть реализованы с помощью СПЕАТЕ. 
Следовательно, Стандартная Программа должна принять что слова определенные 
через ѴАРІАВЙЕ, С0М5ТАІМТ, :, и т.д., не могут иметь никаких полей данных. Нет 
никакого способа для Стандартной Программы изменить значение константы или 
заменить значение определения через двоеточие. 00Е5> часть определяющего слово 
работает на поле данных. Так как только СРЕАТЕ слова имеют поля данных, Р0Е5> 
может быть только объединено с СПЕАТЕ или словом которое вызывает СПЕАТЕ. 

В А№ Рогіій, РІШ, ['] и ' (Сіск) возвращают неопределенный объект называемый 
"идентификатор исполнения". Есть только несколько вещей, которые могут быть 
сделаны с идентификатором исполнения. Идентификатор может быть передан в 
ЕХЕСІІТЕ для выполнения слова, идентификатор исполнения которого получен с 
помощью 1 (Ііск) или скомпилирован в текущее определение с помощью СОМРШЕ, . 
Идентификатор может также быть сохранен в переменной и использован позже. 
Наконец, если слово, идентификатор исполнения которого получен с помощью ' 
(Сіск), было определено через СПЕАТЕ , >ВООУ преобразует идентификатор 
исполнения в адрес области данных слова. 

Одна вещь, которая определенно не может быть сделана с идентификатором 
исполнения - это использование ! или , для записи его в объектный код 
определения Рогіій. Эта методика иногда используется в реализациях, где 
объектный код - это список адресов (шитый код) и идентификатор исполнения - 
также адрес. Однако А№ Рогіій разрешает реализации с чистым кодом, где это не 
будет работать. 
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Е.4.2 Стеки 

В некоторых реализациях РоШН, возможно найти адрес стека в памяти и 
манипулировать стеком как массивом ячеек. Эта методика, однако, не переносимая. 
В некоторых системах, особенно в аппаратно реализованных системах РоШН, стеки 
могли бы быть в части памяти, которая не может быть адресована с помощью 
программы или не могла бы быть в памяти вообще. РоШН стеки параметров и 
возвратов должны обрабатываться как стеки. 

Стандартная Программа может использовать стек возвратов непосредственно только 
для временного хранения значений. Каждое значение, полученное или удаленное со 
стека возвратов с использованием К@, К>, или 2Р>, должно было быть положенным 
на стек явным использованием Ж или 2>Р. Даже это должно быть сделано 
осторожно, так как система может использовать стек возвратов для хранения 
адресов возврата и параметров управления циклом. Раздел 3.2.3.3 Стек возвратов 
Стандарта имеет список ограничений. 

Е.5 Дисциплины соглашения КОМ приложений 

Когда Стандартная Система предоставляет область данных, которая является 
однородно читаемой и записываемой, мы можем называть эту среду "КАМ-опІу". 

Программы, предназначенные для КОМ приложений должны делить область данных, по 
крайней мере, на две части: записываемую и читаемую не инициализируемую часть 
называемую "КАМ", и инициализируемую часть только для чтения называемую "КОМ". 
Третья возможность, записываемая и читаемая инициализируемая часть, обычно 
называемая "инициализируемая КАМ", не относится к этой дисциплине. Стандартная 
Программа должна явно инициализировать область данных КАМ как необходимо. 

Разделение области данных в РАМ и РОМ значимо только в течение жизни РОМ 
программы. Если КОМ программа - стандартно разработанная система, она имеет 
такую же самую систематику как обычная КАМ-опІу система. 

Слова, затрагиваемые преобразованием из КАМ-опІу в смешанную КАМ и РОМ среду: 

, (сотта) АІЛбИ АИ6МЕ0 АШОТ С, СКЕАТЕ НЕКЕ ІІІЧІІ5Е0 
( ѴАРІАВІ_Е всегда обращается к области данных РАМ.) 

За исключением , (запятая) и С, эти слова значимы в КОМ и РАМ областях данных. 

Для выбора области данных, этим словам могли бы предшествовать селекторы РАМ и 
КОМ. Например: 

РОМ СКЕАТЕ 0ИЕ5 32 АШОТ 0ИЕ5 32 1 РІШ КАМ 

создало бы таблицу в области данных КОМ. Сохранение данных в РАМ области данных 
при производстве программы для РОМ было бы неопределенной ситуацией. 

Прямая реализация этих селекторов поддерживала бы отдельные счетчики адреса для 
каждой области. Значение счетчика было бы возвращено НЕКЕ и изменено , 

(запятая), С, , АІЛ6ІМ, и АШОТ, в РАМ и РОМ, просто выбором соответствующего 
счетчика адреса. Эта методика могла бы быть расширена на дополнительное 
разделение области данных. 
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Е.6 Резюме 



А№ РогІИ, стандарт не может и не должен вынуждать кого либо записывать 
переносимую программу. В ситуации, где первостепенна производительность, 
программист, поощряется использовать каждую уловку в книге. С другой стороны, 
если необходима переносимость на широкое разнообразие систем, А№ РогН 
предусматривает для выполнения этого инструментальные средства. Вероятно, нет 
никакой такой вещи как полностью переносная программа. Программист, используя 
это руководство, должен разумно взвешивать компромиссы обеспечения 
переносимости на специфические машины. Например, машины использующие числа 
величин со знаком редки и вероятно не заслуживают, многих размышлений. Но, 
системы с различными размерами ячеек будут, конечно, встречаться и должны быть 
предусмотрены. В общем, создание переносимой программы проясняет, и процесс 
размышления программиста и заключительную программу. 
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Р. Алфавитный список слов (информационное приложение) 

В следующем списке, последняя, четырехразрядная, часть номера ссылки 
устанавливает последовательность соответствующую алфавитному порядку всех 
стандартных слов. Первые две или три части указывают набор слов и раздел 
словаря, в котором слово определено. 


. 6 . 1.0010 

.6.1.0030 

.6.1.0040 

.6.1.0050 

.6.2.0060 

.6.1.0070 

.6.1.0080 

11.6.1.0080 

13.6.1.0086 

.6.1.0090 

. 6 . 1.0100 

. 6 . 1.0110 

. 6 . 1.0120 

.6.1.0130 

.6.1.0140 

.6.1.0150 

.6.1.0160 

17.6.1.0170 

.6.1.0180 

.6.1.0190 

. 6 . 2.0200 

. 6 . 2.0210 

15.6.1.0220 

.6.1.0230 

.6.1.0240 

17.6.1.0245 

.6.1.0250 

.6.2.0260 

.6.1.0270 

.6.2.0280 

.6.1.0290 

.6.1.0300 

.6.1.0310 

.6.1.0320 

.6.1.0330 

.6.2.0340 

.6.1.0350 

8.6.1.0360 

.6.1.0370 

.6.1.0380 

8.6.1.0390 


# . 

#> 

#5 

#ТІВ 


( . . . . 

( . . . . 

( І_ОСАІ_ ) 


*/ . . 
*/М00 
+ . . 

+! 

+ ЮОР 


-ТРАШИб 


■( . 

. Р . 

.5 . 

/ . 

/М00 ... 

/5ТРІМ6 

Ѳ< . 

Ѳ<> .... 

0 = . 

Ѳ> . 

1 + . 

1 - . 

2! . 

2* . 

2/ . 

2>Р .... 

2@ . 

гсоизтАімт 
2РР0Р .. 
201ІР . . . 

2І_ІТЕРАІ_ 


"зЮге" . соре 

"питЬег-зідп". СОРЕ 

"питЬег-зідп-дгеаІег". СОРЕ 

"питЬег-зідп-з". СОРЕ 

"питЬег-І-і-Ь". СОРЕ ЕХТ 

"Иск" . СОРЕ 

"рагеп". СОРЕ 

"рагеп".РІІ_Е 

"рагеп-іосаі-рагеп".І_ОСАІ_ 

"зіаг". СОРЕ 

"зіаг-зіазіі". СОРЕ 

"зІаг-зІазП-тосІ". СОРЕ 

"ріиз". СОРЕ 

"ріиз-зіоге". СОРЕ 

"ріиз-іоор". СОРЕ 

"сотта". СОРЕ 

"тіпиз". СОРЕ 

"сіазіі-іігаіііпд".5ТРІМ6 

"сіоі". СОРЕ 

"сіоі-диоііе". СОРЕ 

"сіоі-рагеп". СОРЕ ЕХТ 

"сіоі-г". СОРЕ ЕХТ 

"сіоі-з".Т00ЦЗ 

"зіазіі". СОРЕ 

"зІазП-тосІ". СОРЕ 

"зіазіі-зіігіпд".5ТРІМ6 

"гего-іезз". СОРЕ 

"гего-поі-едиаіз". СОРЕ ЕХТ 

"гего-едиаіз". СОРЕ 

"гего-дгеаіег". СОРЕ ЕХТ 

"опе-ріиз". СОРЕ 

"опе-тіпиз". СОРЕ 

"Іил/о-зіоге". СОРЕ 

"Іил/о-зіаг". СОРЕ 

"Імо-зіазіі". СОРЕ 

"Тмо-Ю-г" . СОРЕ ЕХТ 

"Імо-Теіісіі". СОРЕ 

"Ііл/о-сопзіапі;".001ІВЦЕ 

"Імо-сігор". СОРЕ 

"Іио-сіире". СОРЕ 

"Імо-Іііегаі".РОІІВЦЕ 


.41 

.41 

.41 

.41 

.64 

.41 

.41 

.97 

122 

.42 

.42 

.42 

.42 

.42 

.42 

.43 

.43 

140 

.43 

.43 

.64 

.64 

129 

.44 

.44 

140 

.44 

.64 

.44 

.64 

.44 

.44 

.44 

.44 

.44 

.64 

.45 

.80 

.45 

.45 

.80 
































































































































.6.1.Ѳ4ѲѲ 20ѴЕР . "ІілЮ 

.6.2.Ѳ41Ѳ 2Р> "ІИл/О 

.6.2.0415 2Р@ "Іио 

8.6.2.0420 2РОТ ."іѵѵо 


оѵег". СОРЕ .45 

г-Ггот" . СОРЕ ЕХТ.64 

г-Ге^сИ" . СОРЕ ЕХТ.65 

гоіе" . 001ІВІ.Е ЕХТ.82 
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.6.1.0430 

8.6.1.0440 

.6.1.0450 

.6.2.0455 

.6.1.0460 

15.6.2.0470 

.6.1.0480 

.6.1.0490 

.6.2.0500 

.6.1.0530 

.6.1.0540 

.6.1.0550 

12.6.1.0558 

.6.1.0560 

.6.1.0570 

.6.1.0580 

15.6.1.0600 

.6.2.0620 

.6.1.0630 

.6.1.0650 

.6.1.0670 

9.6.2.0670 

.6.1.0680 

9.6.2.0680 

.6.1.0690 

.6.1.0695 

.6.2.0700 

15.6.2.0702 

.6.1.0705 

.6.1.0706 

14.6.1.0707 

.6.1.0710 

16.6.2.0715 

.6.1.0720 

15.6.2.0740 

10.6.1.0742 

.6.1.0750 

.6.1.0760 

11.6.1.0765 

.6.1.0770 

17.6.1.0780 

7.6.1.0790 

7.6.1.0800 

7.6.1.0820 

15.6.2.0830 

.6.1.0850 

.6.2.0855 

.6.1.0860 

.6.1.0870 

.6.2.0873 

9.6.1.0875 


25ЫАР .. 
2ѴАРІАВІ.Е 


: ШМАМЕ 
; СООЕ 


<# 

о 


>ВООУ . . 
>Р1_0АТ . 

>ІМ .... 
>і\ііімвер 

>р . 

? 

700 .... 

701ІР . . . 

@ . 

АВОРТ . . 
АВОРТ . . 
АВОРТ" . 
АВОРТ" . 
АВ5 .... 
АССЕРТ . 
АСАІМ .. 
АНЕАО .. 
АІ.І6М . . 
АІЛ6МЕ0 
АЕЕОСАТЕ 
АІ_І_ОТ . . 
АЕ50 . . . 
АШ .... 
А55ЕМВЕЕР 
АТ-ХУ .. 
ВАЗЕ ... 
ВЕ6ІМ .. 
В!Ш .... 

ВЕ . 

ВІ_АІ\ІК . . 
ВЕК .... 
ВЕОСК .. 
ВЕІРРЕР . 
ВУЕ .... 

С! . 

С" . 

С, . 

С@ . 

САЗЕ . . . 
САТСН .. 


"Емо-змар". 

"Емо-ѵагіаЬІе" 

"соіоп" . 

"соіоп-по-пате" ... 

"зетісоіоп" . 

"зетісоіоп-сосіе" . . 

"Іезз-ЕИап". 

"Іезз-питЬег-зідп" 

"поі-едиаіз". 

"едиаіз". 

"дгеаЕег-ЕИап" 

"Ео-Ьосіу". 

"Ео-ТІоаЕ". 

"Ео-іп". 

"Ео-питЬег" . 

"Ео-г". 

"диезЕіоп". 

"диезЕіоп-сІо". 

"диезЕіоп-сІире" . . . 
"ТеЕсИ". 


"аЬогЕ-диоЕе" 
"аЬогЕ-диоЕе" 
"аЬз". 


"аЕ-х-у" 


"Ь-1" 


"Ь-1-к" 


"с-зЕоге" 

"с-диоЕе" 

"с-сотта" 

"с-ТеЕсЕі" 


. СОРЕ 

.ООЕІВЕЕ 

. СОРЕ 

. СОРЕ ЕХТ 

. СОРЕ 

....Т00ЕЗ ЕХТ 

. СОРЕ 

. СОРЕ 

. СОРЕ ЕХТ 

. СОРЕ 

. СОРЕ 

.СОРЕ 

. РЮАТІМ6 

.СОРЕ 

.СОРЕ 

.СОРЕ 

.Т00Е5 

.СОРЕ ЕХТ 

.СОРЕ 

.СОРЕ 

.СОРЕ 

ЕХСЕРТІОМ ЕХТ 

.СОРЕ 

ЕХСЕРТІОМ ЕХТ 

.СОРЕ 

.СОРЕ 

.СОРЕ ЕХТ 

. . . .Т00І.5 ЕХТ 

.СОРЕ 

.СОРЕ 

.МЕМОРУ 

.СОРЕ 

...5ЕАРСН ЕХТ 

.СОРЕ 

... .Т00І.5 ЕХТ 

. РАСІІЛТУ 

.СОРЕ 

.СОРЕ 

. РІІ_Е 

.СОРЕ 

. 5ТРІМ6 

.В1_0СК 

.ВЮСК 

.ВЮСК 

. . . .Т00І.5 ЕХТ 

.СОРЕ 

.СОРЕ ЕХТ 

.СОРЕ 

.СОРЕ 

.СОРЕ ЕХТ 

.... ЕХСЕРТІОМ 


.45 

.81 

.45 

.65 

.45 

130 

.46 

.46 

.65 

.46 

.46 

.46 

108 

.46 

.46 

.47 

129 
.65 
.47 
.47 
.47 
.88 
.47 
.88 
.47 
.48 
.66 

130 
.48 
.48 
125 
.48 
138 
.48 
130 
.90 
.49 
.49 
.97 
.49 
140 
.75 
. 75 
.76 
130 
.49 
.66 
.49 
.49 
.66 
.87 
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.6.1.0880 СЕІ_І_+ 


"сеіі-ріиз" 


СОРЕ.49 






















































































































































.6.1.0890 

.6.1.0895 

.6.1.0897 

.6.1.0898 

11.6.1.0900 

17.6.1.0910 

17.6.1.0920 

15.6.2.0930 

17.6.1.0935 

.6.2.0945 

.6.1.0950 

.6.2.0970 

.6.1.0980 

.6.1.0990 

. 6 . 1.1000 

11 . 6 . 1.1010 

15.6.2.1015 

15.6.2.1020 

8.6.1.1040 

8.6.1.1050 

8.6.1.1060 

8.6.1.1070 

8.6.1.1075 

8.6.1.1080 

8.6.1.1090 

8 . 6 . 1.1100 

8 . 6 . 1.1110 

8 . 6 . 1.1120 

12.6.1.1130 

8.6.1.1140 

8.6.1.1160 

.6.1.1170 

16.6.1.1180 

11.6.1.1190 

. 6 . 1.1200 

12.6.2.1203 

12.6.2.1204 

12.6.2.1205 

12.6.2.1207 

12.6.2.1208 
12.6.2.1209 

8 . 6 . 1.1210 

8 . 6 . 1.1220 

8.6.1.1230 

.6.1.1240 

.6.1.1250 

.6.1.1260 

8.6.2.1270 

15.6.1.1280 

.6.1.1290 


СЕІ.1.5 .... 

СНАР . 

СНАР+ . 

СНАР5 .... 
СЮ5Е-РИЕ 
СМОѴЕ .... 
СМОѴЕ> ... 

СООЕ . 

СОМРАРЕ . . 
СОМРІІ.Е, 
С0ІМ5ТАІМТ . 
СОІМѴЕРТ .. 
СОЕІМТ .... 

СР . 

СРЕАТЕ . . . 
СРЕАТЕ-РІІ.Е 
С5-РІСК . . 
С5-Р0І_І_ . . 

Р+ . 

О- . 

о . 

О.Р . 

О0< . 

О0= . 

02* . 

02/ . 

0< . 

0= . 

0>Р . 

0>5 . 

0АВ5 . 

ОЕСІМАЕ . . 
ОЕРІМІТІО№ 
ОЕЕЕТЕ-РІЕЕ 
ОЕРТН .... 

ОР! . 

0Р@ . 

0РАЕІ6ІМ . . 
ОРАИб^О 
ОРЕОАТ+ .. 
0РЕ0АТ5 .. 

ОМАХ . 

ОМІІЧ . 

0ІМЕ6АТЕ .. 

00 . 

00Е5> .... 

ОРОР . 

ОЕІ< . 

ОІІМР . 

ОІІР . 


"сИаг" . 

"сііаг-ріиз" 

"сііагз" 


"с-тоѵе"... 
"с-тоѵе-ир" 


"сотрііе-сотта" 


"с - г" 


"с-з-ріск". 

"с-5-гоіі". 

"сі-ріиз". 

"сі-тіпиз". 

"сі-сіоН". 

"сі-сіоЕ-г". 

"сі-гего-іезз" . . 
"сі-гего-едиаіз" 
"сІ-Емо-зЕаг" . . . 
"сІ-Емо-зІазІі" . . 
"сІ-Іезз-ЕІіап". . 

"сі-едиаіз". 

"сІ-Ео-Г'. 

"сІ-Ео-з". 

"сІ-аЬз". 


"сІ-Т-зЕоге". . . 
"сІ-Т-ЕеЕсІі". . . 
"сІ-Т-аІідп". . . 
"сІ-Т-аІідпесІ". 
"сІ-ТІоаЕ-рІиз" 
"сІ-ТІоаЕз" 

"сі-тах". 

"сі-тіп". 

"сІ-педаЕе" 


"сіоез" 


"сі-и-іезз" 


"сіире" 


. СОРЕ 

. СОРЕ 

. СОРЕ 

. СОРЕ 

. РІІ_Е 

. 5ТРІМ6 

. 5ТРІМ6 

...Т0015 ЕХТ 

. 5ТРІМ6 

....СОРЕ ЕХТ 

.СОРЕ 

....СОРЕ ЕХТ 

.СОРЕ 

.СОРЕ 

.СОРЕ 

. РІІ_Е 

. . .Т00І.5 ЕХТ 
. . .Т001.5 ЕХТ 

. ООЕІВЕЕ 

. 001ІВІ_Е 

. 001ІВІ_Е 

. ООЕІВЕЕ 

. ООЕІВЕЕ 

. ООЕІВЕЕ 

. ООІІВЬЕ 

. ООЕІВЕЕ 

. ООІІВЬЕ 

. ООІІВЕЕ 

. . . . РЕ0АТІІМ6 

.ООЕІВЕЕ 

.ооивіЕ 

. СОРЕ 

.5ЕАРСН 

.РІІ_Е 

. СОРЕ 

РЕ0АТІІМ6 ЕХТ 
РЕ0АТІМ6 ЕХТ 
РЮАТІМ6 ЕХТ 
РЮАТІМ6 ЕХТ 
РІ_ОАТІМе ЕХТ 
РЕ0АТІМ6 ЕХТ 

.ООІІВЕЕ 

.ООІІВЕЕ 

.ООЕІВЕЕ 

. СОРЕ 

. СОРЕ 

. СОРЕ 

. . ООЕІВЕЕ ЕХТ 

.Т00Е5 

. СОРЕ 


.50 

.50 

.50 

.50 

.97 

140 

140 

130 
140 
.66 
.50 
.67 
.50 
.50 
.50 
.97 

131 
131 
.81 
.81 
.81 
.81 
.81 
.81 
.81 
.82 
.82 
.82 
109 
.82 
.82 
.51 
136 
.97 
.51 
112 
113 
113 
113 
113 
113 
.82 
.82 
.82 
.51 
.51 
.52 
.83 
129 
.52 
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15.6.2.1300 

10.6.2.1305 

10.6.2.1306 

10.6.2.1307 
.6.1.1310 
.6.1.1320 

10.6.2.1325 

7.6.2.1330 

.6.2.1342 

.6.2.1343 


ЕОІТОР . 

ЕКЕУ ."е-кеу". 

ЕКЕѴ>СНАР . "е-кеу-Ео-сИаг" . 

ЕКЕУ? ."е-кеу-диезЕіоп" 

ЕЕЗЕ . 

ЕМІТ . 

ЕМІТ? ."ешіЕ-диезЕіоп" . 

ЕМРТУ- ВЕІРРЕРЗ . 

ЕІ\ЮСА5Е ."епсі-сазе". 

ЕІ\ЮОР ."епсІ-оТ". 


...Т00Е5 ЕХТ 
РАСІЕІТУ ЕХТ 
РАСІЕІТУ ЕХТ 
РАСІЕІТУ ЕХТ 

. СОРЕ 

. СОРЕ 

РАСІЕІТУ ЕХТ 
... ВЕОСК ЕХТ 
... .СОРЕ ЕХТ 
... .СОРЕ ЕХТ 


132 

.91 

.91 

.91 

.52 

.52 

.91 

.77 

.67 

.67 



































































































































































.6.1.1345 

.6.2.1350 

.6.1.1360 

7.6.1.1360 

.6.1.1370 

.6.1.1380 

.6.2.1390 

12.6.1.1400 

12.6.1.1410 

12.6.2.1415 

12.6.1.1420 

12.6.1.1425 

12.6.2.1427 

12.6.1.1430 

12.6.1.1440 

12.6.1.1450 

12.6.1.1460 

12.6.1.1470 

12.6.1.1472 

12.6.2.1474 

12.6.2.1476 

12.6.2.1477 
12.6.1.1479 

12.6.1.1483 

12.6.2.1484 
.6.2.1485 

12.6.2.1486 

12.6.2.1487 

12.6.2.1488 

12.6.2.1489 

12.6.2.1491 

12.6.1.1492 

12.6.2.1493 

12.6.2.1494 
12.6.1.1497 
12.6.1.1500 
12.6.1.1510 
12.6.2.1513 

12.6.2.1515 

12.6.2.1516 
11.6.1.1520 


ЕІМѴІРОММЕІМТ? 

ЕРА5Е . 

ЕѴАІ.ІІАТЕ . . . 
ЕѴАШАТЕ . . . 
ЕХЕСІІТЕ .... 

ЕХІТ . 

ЕХРЕСТ . 

Р! . 

Р* . 

р * * 

Р+ . 

Р- . 

Р. 

Р/ . 

РѲ< . 

РѲ= . 

р< . 

Р>0 . 

р§ . 

РАВЗ . 

РАС05 . 

РАСОЗН . 

РАІЛ6М . 

РАИ6МЕ0 . . . 

РАІ.00 . 

РАІ_5Е . 

РАЗІМ . 

РА5ІІМН . 

РАТАМ . 

Р АТАМ 2 . 

РАТАІМН . 

РС0М5ТАМТ .. 

РС05 . 

РСОЗН . 

РОЕРТН . 

РОРОР . 

РРЕІР . 

РЕ. 

РЕХР . 

РЕХРМ1 . 

РІЕЕ-Р05ІТІ0М 


"епѵігоптепЕ-диегу" 


"Т-зЕоге" . 

"Т-зЕаг". 

"Т-зЕаг-зЕаг". 

"Т-рІиз". 

"Т-тіпиз". 

’Т-сІоЕ". 

"Т-зІазІі". 

"Т-гего-Іезз-ЕІіап" 
"Т-гего-едиаІз"... 

"Т-Іезз-ЕНап". 

"Т-Ео-сГ. 

"Т-ТеЕсІі". 

"Т-аЬз". 

"Т-а-соз". 

"Т-а-созІі". 

"Т-аІідп". 

"Т-аІідпесІ". 

"Т-а-Іод". 


"Т-а-зіпе". 

"Т-а-сіпсІі". . . . 

"Т-а-Еап". 

"Т-а-Еап-Емо". . 
"Т-а-Еап-Іі" . . . . 
"Т-сопзЕапЕ" . . . 

"Т-соз". 

"Т-созЕГ . 

"Т-сІерЕІ'і". 

"Т-сІгор". 

"Т-сІире". 

"Т-е-сІоЕ". 

"Т-е-х-р-т-опе" 


. СОРЕ 

... .СОРЕ ЕХТ 

. СОРЕ 

. ВЮСК 

. СОРЕ 

.СОРЕ 

....СОРЕ ЕХТ 
. . . . РЮАТІМ6 
. . . .РІ_ОАТІМе 
РЮАТІМ6 ЕХТ 
. . . . РІ_0АТІМ6 
.... РЕ0АТІМ6 
РЮАТІМ6 ЕХТ 
. . . . РІ.0АТІМ6 
.... РЕ0АТІМ6 
. . . . РІ_0АТІМ6 
. . . . РЮАТІМ6 
. . . . РЮАТІМ6 
. . . . РЮАТІМ6 
РЕ0АТІМ6 ЕХТ 
РІ_ОАТІМе ЕХТ 
РЮАТІМ6 ЕХТ 
... .рі_ОАТіме 
. . . . РЮАТІМ6 
РЮАТІМ6 ЕХТ 
....СОРЕ ЕХТ 
РЮАТІМС ЕХТ 
РЮАТІМ6 ЕХТ 
РЕ0АТІМ6 ЕХТ 
РІ.0АТІМ6 ЕХТ 
РЕ0АТІМ6 ЕХТ 
. . . . РІ_0АТІМ6 
РЮАТІМ6 ЕХТ 
РЕ0АТІМ6 ЕХТ 
. . . . РІ.0АТІМ6 
.... РЕ0АТІМ6 
. . . .РІ_ОАТІМе 
РЮАТІМС ЕХТ 
РЮАТІМС ЕХТ 
РЮАТІМ6 ЕХТ 
. РІЕЕ 


.53 

.67 

.53 

.76 

.53 

.53 

.68 

109 

109 

113 

109 

109 

113 
109 
109 
109 

109 

110 
110 

114 
114 
114 
110 
110 
114 
.68 
114 
114 
114 
114 

114 
110 

115 
115 
110 
110 
110 
115 
115 
115 
.97 
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11.6.1.1522 

11.6.2.1524 

.6.1.1540 

.6.1.1550 

16.6.1.1550 

12.6.1.1552 

12.6.2.1553 

12.6.2.1554 

12.6.1.1555 

12.6.1.1556 

12.6.2.1557 

12.6.1.1558 
7.6.1.1559 

11.6.2.1560 

.6.1.1561 

12.6.1.1562 

12.6.1.1565 

12.6.1.1567 

15.6.2.1580 


РІІ.Е-5І2Е 

РІІ.Е-5ТАТІІ5 

РІІ_І_ . 

РІШ . 

РІШ . 

РІ_ІТЕРА1_ . 

РЕМ . 

РЕМР1 .... 
РЕ0АТ+ ... 
РЕ0АТ5 ... 

РЬОС . 

РЕООР .... 
Р ЬЕІЗН .... 
РЕІІЗН-РІЕЕ 
РМ/МОО ... 

РМАХ . 

РМІМ . 

РМЕСАТЕ .. 
РОРСЕТ ... 


"Т-ІіЕегаІ". . 

"Т-1-п" . 

"Т-1-п-р-опе" 
"ТІоаЕ-рІиз" . 


"Т-Іод" 


"Т-ш-зІазИ-тосІ" 

"Т-тах" . 

"Т-тіп". 

"Т-педаЕе". 


.РІЕЕ 

....РІЕЕ ЕХТ 

. СОРЕ 

. СОРЕ 

.5ЕАРСН 

....РЕ0АТІМ6 
РЕ0АТІМ6 ЕХТ 
РЕ0АТІМ6 ЕХТ 
....РЕ0АТІМ6 
....РЕ0АТІМ6 
РЕ0АТІМ6 ЕХТ 
....РЕ0АТІМ6 

. ВЕОСК 

....РІЕЕ ЕХТ 

. СОРЕ 

....РЕ0АТІМ6 
....РЕ0АТІМ6 
....РЕ0АТІМ6 
...Т00Е5 ЕХТ 


.97 

102 

.53 

.53 

136 

111 

115 

115 

111 

111 

115 

111 

.76 

102 

.54 

111 

111 

111 

132 





































































































































































16.6.2.1590 
16.6.1.1595 
12.6.1.1600 
14.6.1.1605 
12.6.1.1610 
12.6.1.1612 

12.6.2.1613 

12.6.2.1614 
12.6.2.1616 

12.6.2.1617 

12.6.2.1618 
12.6.1.1620 

12.6.2.1625 

12.6.2.1626 
12.6.1.1630 
12.6.2.1640 
16.6.1.1643 
16.6.1.1647 

.6.1.1650 

.6.2.1660 

.6.1.1670 

.6.1.1680 

.6.1.1700 

.6.1.1710 

11.6.1.1717 

11.6.1.1718 
.6.1.1720 
.6.1.1730 
.6.1.1750 

10.6.1.1755 

6.1.1760 

7.6.2.1770 


РОРТН . 

РОРТН -Іл/ОРОІЛЗТ 


РОѴЕР . "Т-оѵег". 

РРЕЕ . 

РРОТ ."Т-гоІе". 

РРОЕІШ .'Т-гоипсі". 

Р5."Т-5-сІоІ:". 

РЗІМ .’Т-зіпе". 

Р5ІМС05 .’Т-зіпе-соз" . . . 

Р5ІІМН .'Т-сіпсИ". 

РЗрРТ . "Т-^иаге- гею!" 

Р5ЫАР ."Т-змар". 

РТАМ ."Т-Іап". 

РТАМИ ."Т-Іап-И". 

РѴАРІАВІ.Е ."Т-ѵагіаЬІе" . . . 

Р~ ."Т-ргохіта1:е" . . 


6ЕТ-СІІРРЕМТ . 

6ЕТ -ОРОЕР . 

НЕКЕ . 

НЕХ . 

НОЮ . 

I . 

ІР . 

ІММЕОІАТЕ . 

ІМСШОЕ-РІЕЕ . 

ІИСЮРЕО . 

ІМѴЕРТ . 

3 . 

КЕУ . 

КЕУ? ."кеу^иезііоп" 

І_ЕАѴЕ . 

ЕІ5Т . 


..5ЕАРСН ЕХТ 

.5ЕАРСН 

. . . . РІЮАТІИС 

.МЕМОРУ 

. . . . РЮАТІМ6 
. . . . РЮАТІМ6 
РІЮАТІИС ЕХТ 
РІЮАТІИС ЕХТ 
РЕ0АТІМ6 ЕХТ 
РЮАТІМ6 ЕХТ 
РЮАТІМ6 ЕХТ 
....РЕ0АТІМ6 
РІЮАТІИС ЕХТ 
РЕ0АТІМ6 ЕХТ 
. . . . РІЮАТІИС 
РЕ0АТІМ6 ЕХТ 

.5ЕАРСН 

.5ЕАРСН 

. СОРЕ 

... .СОРЕ ЕХТ 

. СОРЕ 

. СОРЕ 

. СОРЕ 

.СОРЕ 

. РІІ_Е 

. РІІ_Е 

.СОРЕ 

.СОРЕ 

.СОРЕ 

. . . .РАСІІ.ІТУ 

.СОРЕ 

. . .ВЮСК ЕХТ 


138 

137 

111 

126 

111 

111 

115 

116 
116 
116 
116 
111 
116 
116 
112 
116 
137 
137 
.54 
.68 
.54 
.54 
.54 
.54 
.98 
.98 
.55 
.55 
.55 
.90 
.56 
. 77 
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.6.1.1780 

7.6.1.1790 

13.6.2.1795 

.6.1.1800 

.6.1.1805 

.6.1.1810 

8.6.1.1820 

8.6.1.1830 

.6.2.1850 

.6.1.1870 

.6.1.1880 

.6.1.1890 

.6.1.1900 

10.6.2.1905 

.6.1.1910 

.6.2.1930 

.6.2.1950 

16.6.2.1965 

11.6.1.1970 

.6.1.1980 

16.6.2.1985 

.6.1.1990 

. 6 . 2.2000 

10.6.1.2005 

.6.2.2008 

.6.2.2030 

.6.1.2033 

12.6.2.2035 


І_ІТЕРАІ_ 
І_ОАО . . . 
І_0САІ_5 | 
ЮОР . . . 
І.5НІРТ . 
М* . 

мѵ .... 

м+ . 

МАРКЕР . 
МАХ .... 
МІМ .... 
МОО .... 
МОѴЕ ... 

М5 . 

МЕСАТЕ . 
МІР .... 

ОР . 

ОМІ.У . . . 
ОРЕИ-РИ-Е 

ОР . 

ОРОЕР . . 
ОѴЕР ... 
РАО .... 
РАСЕ ... 
РАР5Е .. 
РІСК ... 
Р05ТР0МЕ 
РРЕСІ5І0М 


.СОРЕ 

.ВЮСК 

"1осаІ5-Ьаг" . І_ОСАІ_ ЕХТ 

.СОРЕ 

"1-5НІП" .СОРЕ 

"т-5І;аг" .СОРЕ 

"т-зііаг-зіазіі" . ООІІВІЕ 

"т-ріиз" . 001ІВІ.Е 

.СОРЕ ЕХТ 

.СОРЕ 

.СОРЕ 

.СОРЕ 

.СОРЕ 

. РАСІІЛТУ ЕХТ 

.СОРЕ 

.СОРЕ ЕХТ 

.СОРЕ ЕХТ 

.5ЕАРСН ЕХТ 

. РІІ_Е 

.СОРЕ 

.5ЕАРСН ЕХТ 

.СОРЕ 

.СОРЕ ЕХТ 

. РАСІІЛТУ 

.СОРЕ ЕХТ 

.СОРЕ ЕХТ 

.СОРЕ 

. РЮАТІМС ЕХТ 


.76 

.76 

123 

.56 

.56 

.56 

.82 

.82 

.68 

.56 

.56 

.56 

.56 

.91 

.57 

.68 

.68 

138 

.99 

.57 

138 

.57 

.69 

.91 

.69 

.69 

.57 

117 














































































































































16.6.2.2037 
.6.2.2040 
.6.1.2050 
11.6.1.2054 
11.6.1.2056 
.6.1.2060 
.6.1.2070 
11.6.1.2080 
11.6.1.2090 
. 6 . 1.2120 
.6.2.2125 
7.6.2.2125 
11.6.2.2125 
11.6.2.2130 
.6.1.2140 

11.6.1.2142 

12.6.1.2143 
14.6.1.2145 
11.6.1.2147 

.6.2.2148 

.6.2.2150 

.6.1.2160 

.6.1.2162 


РРЕѴІ0ЕІ5 
(}ЕІЕРѴ . 
0>ЕІІТ . . 


Р/О ."г-о" 

РА/ . "г-ѵі" . . . . 

Р> . "г-Тгот". 

Р@ ."г-ТеЕсІі" 


РЕАО-РІЕЕ . 

РЕАО-ИМЕ . 

РЕСІІР5Е . 

РЕРІЕЕ . 

РЕРІЕЕ . 

РЕРІЕЕ . 

РЕИАМЕ-РІЕЕ . 

РЕРЕАТ . 

РЕР05ІТІ0М-РІЕЕ . 

РЕРРЕ5ЕІМТ . 

РЕ5І2Е . 

РЕ5І2Е-РІЕЕ . 

РЕ5Т0РЕ- ІІМРЕІТ . 

РОЕЕ . 

РОТ ."гоЕе" . . . 

РЗНІРТ ."г-зИІТЕ" 


ЗЕАРСН ЕХТ 
. .СОРЕ ЕХТ 

. СОРЕ 

.РІЕЕ 

.РІЕЕ 

. СОРЕ 

. СОРЕ 

.РІЕЕ 

.РІЕЕ 

. СОРЕ 

. .СОРЕ ЕХТ 
. ВЕОСК ЕХТ 
. .РІЕЕ ЕХТ 
. .РІЕЕ ЕХТ 

. СОРЕ 

.РІЕЕ 

..РЕ0АТІІМ6 
....МЕМОРѴ 

.РІЕЕ 

. .СОРЕ ЕХТ 
. .СОРЕ ЕХТ 

. СОРЕ 

. СОРЕ 


138 
.69 
.57 
.99 
.99 
.57 
.58 
.99 
100 
.58 
.69 
. 77 
102 
102 
.58 
100 
112 
126 
100 
.70 
.70 
.58 
.58 
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.6.1.2165 

11.6.1.2165 

.6.1.2170 

7.6.1.2180 

.6.2.2182 

7.6.2.2190 

17.6.1.2191 

16.6.1.2192 

15.6.1.2194 

16.6.1.2195 
16.6.1.2197 
12 . 6 . 2.2200 
12 . 6 . 2.2202 

12.6.2.2203 

12.6.2.2204 
12.6.2.2206 

12.6.2.2207 

12.6.2.2208 

. 6 . 1.2210 

17.6.1.2212 

.6.1.2214 

.6.1.2216 

.6.2.2218 

11.6.1.2218 

. 6 . 1.2220 

.6.1.2230 

.6.2.2240 

.6.1.2250 

15.6.2.2250 

.6.1.2260 

.6.1.2270 

9.6.1.2275 

7.6.2.2280 

.6.2.2290 

10.6.2.2292 

.6.2.2295 

13.6.1.2295 


5" ."з-діюЕе" 

5" ."з-діюЕе" 

5>0 ."з-Ео-сі". 

ЗАѴЕ-ВЕІРРЕРЗ . 

5АѴЕ- ІІМРЕІТ . 

ЗСР ." 5 - с - г " . . 

ЗЕАРСН . 

ЗЕАРСН-Ы0Р0ЕІ5Т . 

ЗЕЕ . 

5ЕТ-СЕІРРЕІМТ . 

ЗЕТ-0Р0ЕР . 

ЗЕТ- РРЕСІ5І0ІМ . 


5Р ! . "з-Т-зЕоге" . . . . 

5Р@ ."5-Т-ТеЕсН" . . . . 

5РАЕІ6ІМ ."5-Т-а1ідп" . . . . 

5РАЕІ6ІМЕ0 ."5-Т-а1ідпесІ" . . 

5РЕ0АТ+ ."з-ТІоаЕ-рІиз". 

5РЕ0АТ5 ."з-ТІоаЕз". 

ЗІСИ . 

ЗЕІТЕРАЕ . 

5М/РЕМ ."з-т-зіазіі-гет" 

ЗОЕІРСЕ . 

ЗОЕІРСЕ- Ю ."зоигсе-і-сГ. . . 

ЗОЕІРСЕ- Ю ."зоигсе-і-сГ... 


ЗРАСЕ . . 
ЗРАСЕЗ . 
5РАІМ . . . 
ЗТАТЕ .. 
ЗТАТЕ .. 
5\л/АР . . . 
ТНЕИ . . . 
ТНРОМ . . 
ТНРЕІ . . . 
ТІВ .... 
ТІМЕ&ОАТЕ 

ТО . 

ТО . 


"Е-І-Ь". 

"Еіте-апсІ-сІаЕе" 


. СОРЕ 

.РІЕЕ 

. СОРЕ 

.ВЕОСК 

... .СОРЕ ЕХТ 
...ВЕОСК ЕХТ 

.ЗТРІИС 

.ЗЕАРСН 

.Т00Е5 

.ЗЕАРСН 

.ЗЕАРСН 

РЕ0АТІИ6 ЕХТ 
РЕ0АТІІМ6 ЕХТ 
РЕ0АТІМ6 ЕХТ 
РЕ0АТІИ6 ЕХТ 
РЕ0АТІИ6 ЕХТ 
РЕ0АТІИ6 ЕХТ 
РЕ0АТІИ6 ЕХТ 

. СОРЕ 

.5ТРІІМ6 

. СОРЕ 

. СОРЕ 

... .СОРЕ ЕХТ 

. РІЕЕ 

.СОРЕ 

.СОРЕ 

....СОРЕ ЕХТ 

.СОРЕ 

... Т00ЕЗ ЕХТ 

.СОРЕ 

.СОРЕ 

... ЕХСЕРТІОІМ 
... ВЕОСК ЕХТ 
....СОРЕ ЕХТ 
РАСІЕІТѴ ЕХТ 
....СОРЕ ЕХТ 
.ЕОСАЕ 


.58 

101 

.59 

.77 

.70 

.77 

141 

137 

129 

137 

137 

117 

117 

117 

117 

117 

118 
118 
.59 
141 
.59 
.59 
.70 
101 
.59 
.59 
.70 
.59 
132 
.60 
.60 
.87 
.78 
.71 
.92 
.71 
123 
















































































































































.6.2.2298 

.6.2.2300 

.6.1.2310 

.6.1.2320 

.6.2.2330 

.6.1.2340 

.6.2.2350 

.6.1.2360 

.6.1.2370 

.6.1.2380 

.6.1.2390 

.6.2.2395 

7.6.1.2400 

.6.2.2405 


ТВІІЕ 

ШОК 

ТУРЕ 

и. 

іі. в . 
іі< .. 
іі> .. 
ІІМ* . 
ІІМ/МОО 
ІІІЧЮОР 
ІИМПІ. 

ііічіізео 

ІІРОАТЕ 

ѴАШЕ 


. СОВЕ ЕХТ 

. СОВЕ ЕХТ 

. СОВЕ 

"и-сІоТ". СОВЕ 

"и-сіоі-г". СОВЕ ЕХТ 

"и-Іезз-ІІіап". СОВЕ 

"и-дгеаіег-іііап". СОВЕ ЕХТ 

"и-т-5І;аг". СОВЕ 

"и-т-зіазіі-тосі". СОВЕ 

. СОВЕ 

. СОВЕ 

. СОВЕ ЕХТ 

.ВЮСК 

.СОВЕ ЕХТ 


71 

71 

60 

60 

71 

60 

71 

60 

61 

61 

61 

71 
77 

72 
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.6.1.2410 

11.6.1.2425 

.6.1.2430 

.6.2.2440 

.6.1.2450 

16.6.1.2460 

15.6.1.2465 

11.6.1.2480 

11.6.1.2485 

.6.1.2490 

.6.1.2500 

.6.1.2510 

.6.1.2520 

.6.2.2530 

15.6.2.2531 

15.6.2.2532 

15.6.2.2533 
.6.2.2535 

7.6.2.2535 

.6.1.2540 


ѴАВІАВІ_Е 

VI /О . 

\л/НІІ_Е . . . 
\л/ІТНІМ . . 
ЫОВй .... 
М0В0І.І5Т 
М0В05 . . . 

\л/ВІТЕ-РІІ_Е 
ШІТЕ-І.ІМЕ 

ХОВ . 

[ . 

['] . 

[СНАВ] . . 
[СОМРІІ.Е] 
[ЕІ_5Е] . . 

[ІР] .... 
[ТНЕІМ] . . 

\ . 

\ . 

] . 


.СОВЕ 

"м-о". РІ1_Е 

.СОВЕ 

.СОВЕ ЕХТ 

.СОВЕ 

.5ЕАВСН 

. Т00І.5 

. РІІ_Е 

. РІЕЕ 


"х-ог".СОВЕ 

"ІеТІ-ЬгаскеІ;" .СОВЕ 

"Ьгаске1;-1;іск" .СОВЕ 

"Ьгаскеіі-сііаг" .СОВЕ 

"Ьгаскеі-сотрііе" .СОВЕ ЕХТ 

"Ьгаскеіі-еізе" .Т00Е5 ЕХТ 

"ЬгаскеІ-іТ" . Т00І.5 ЕХТ 

"Ьгаске1;-1;Ііеп" .Т001_5 ЕХТ 

"Ьаскзіазіі" .СОВЕ ЕХТ 

"Ьаскзіазіі" .ВЮСК ЕХТ 

"гідИІі-ЬгаскеІ;" .СОВЕ 


.61 

101 

.62 

.72 

.62 

137 

129 

101 

102 

.62 

.62 

.62 

.63 

.72 

132 

132 

133 
.72 
.78 
.63 


251 

























































































